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The Customer is Tired of Being Ignored! 

Many of the companies in the microcomputer 
industry have developed a very simple customer 
relations policy— they just ignore 

correspondence and phone calls. This may have 
been a cost-effective way of handling the problem 
in an expanding market filled with eager and 
unsophisticated buyers, but experienced business 
people will not put up with this shoddy 
treatment in the current buyer's market. 

The microcomputer industry is still structured 
around the pioneer companies started by a 
technically oriented entrepreneur with little cash 
and no business experience who ran the business 
out of a spare bedroom. These undercapitalized, 
understaffed enterprises made millions because 
there was no competition, and because the 
owners were too busy taking money to the bank 
to worry about the customer. Their problem was 
how to expand fast enough to meet the unfilled 
demands. It didn't matter if the customer was 
unsatisfied because the product was already paid 
for (they don't give refunds if the product doesn't 
work), and there were dozens of new buyers to 
replace every lost customer. 

Good documentation and customer support are 
extremely important for business equipment and 
software. With the large number of vendors 
competing for your dollar today, your decision to 
buy any micro product should be largely based 
on how you will be treated by the company after 
the purchase. In order to help you compare 
customer support policies, The Computer 
Journal is surveying vendors and will publish the 
customer relations policy with the addresses and 
phone numbers. We will also encourage them to 
submit bug fixes, customization notes, and 
interfacing information for publication. 

Realizing that what happens in the real world 
is often different than the published policy, we 
will also publish the experiences of our readers, 
after giving the vendors the opportunity to 



respond. We do need your experiences with 
vendors (both the good and the bad) to help 
others avoid the companies with poor products 
and miserable customer relations. 

Our loyalty is to our readers, and not to any 
possible advertisers. We will not hesitate to 
report bad products and poor customer support, 
but we will need copies of correspondence and 
records of phone calls which we can present to 
the vendors prior to publication. 

We have had a bad experience with a 
computer system we purchased recently. We 
wrote twice for information on an upgrade, but 
they have not answered our letters. We liked 
their product, but will not purchase any other 
equipment from them or recommend their 
equipment to anyone else. We are sending copies 
of the letters to the vendor for their reply before 
publishing the details. 

This magazine is published for you, and it will 
only be as good as you make it. Take time to tell 
us about your vendor experiences, and share 
your bug fixes, customization patches, 
interfacing information and technical tips with 
the other readers. ■ 
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BUILD A VIC-20 EPROM PROGRAMMER 

by Neil Bungard 



Introduction 

About a month ago I was presented with an interesting 
problem. I had acquired a Z-80 based S-100 bus 
microcomputer which had no operating software installed on 
it. I had an operating system stored on paper tape, but I 
needed the operating system on an EPROM before my 
system would run it. The EPROM programmers that I 
looked at were too expensive to justify buying simply to 
program one EPROM, so I looked for an alternative 
solution. It so happened that I had recently purchased a 
VIC-20, so I decided to design an EPROM programmer 
attachment for the VIC-20 and use the VIC-20 to transfer 
the Z-80 operating software from the paper tape to the 
EPROM. The VIC-20 solved my EPROM programming 
problem with exceptional grace. With the VIC-20 and ten 
dollars worth of additional hardware, I was able to enter, 
inspect, program, and verify data on both 2716 (2K by 8) and 
2732 (4K by 8) EPROMs. In addition, the VIC-20 EPROM 
programmer has features not found on even the most 
expensive EPROM programmers. Data to be programmed 
into the EPROM can be entered from cassette tape, 5" 
diskettes, any RS-232 device, from the VIC-20 keyboard, or 
even from another EPROM. 

Circuit Description 

The VIC-20 EPROM programmer circuit diagram is shown 
in Figure 1. This circuit was designed to program 2716 (2K 
by 8) EPROMs, but with minor circuit modifications the 
VIC-20 can program 2732 (4K by 8) EPROMs as well. These 
modifications will be explained in detail, and can be hard 
wired or wired so that "personality modules" can be 
inserted to select between programming 2716s or 2732s. 

The VIC-20 EPROM Programmer performs four basic 
functions: 

1. It can set the address of where data trasfers are to begin 
on the EPROM. 

2. It can read data from a "read only" EPROM. This is used 
in the EPROM duplicate mode. 

3. It can read data from a "programable " EPROM. This is 
used in the program verification mode. 

4. It can program an EPROM. This, of course, is used in the 
program mode. 

To obtain an understanding of the operation of the EPROM 
programmer circuit in each mode, let us look at these four 
basic functions separately. 

The first function, address selection, is accomplished by 
loading three presettable counters with the beginning 
address of where you wish to store or retrieve data on the 
EPROM. The counters are 74LSl93s (IC 1, 2, and 3 in Figure 
1). The inputs of the counters are tied through buffers to the 



data bus of the VIC-20. The outputs of the counters are 
connected to the address lines of the 2716s so that the 
values loaded into the 74LS193s will be present on the 
address lines of the EPROMs. With an address value loaded 
into the 74LS193s and present on both EPROMs, a memory 
read from either EPROM or a memory write to the 
programable EPROM can be accomplished. Once the data 
transfer operation is accomplished, the selected address can 
either be advanced in increments of one, or a new address 
can be loaded into the counters. 

Values are loaded into selected counters by the VIC-20 via 
an Input/Output (I/O) device code generator (IC4). The 
device code generator (a 74LS138) is a three line to eight 
line decoder. Its three input lines are tied through buffers to 
the three lowest order address bits of the VIC-20 address 
bus. When the VIC-20 wants to accomplish an information 
transfer 'either Input or Output) it places the address of 
where the data exchange is to take place onto pins 1, 2, and 
3 of the 74LS138. The VIC-20 then pulses "BLKl" to a logic 
0. This generates a device code pulse on one of eight output 
pins on the 74LS138 which accomplishes a data transfer 
to/from one of eight unique address locations defined by the 
values of AO, Al, and A2. Table 1 shows the eight data 
transfer pulses generated on the EPROM programmer. 
Figure 2 is the timing diagram of the device code pulse 
generated. 

With reference to Table 1, the following software is 
required to operate the device select hardware and set a 
given address location for a memory transfer: 

10 POKE 8195,0 

20 POKE 8192,0 
This program addresses memory location (decimal) on the 
EPROMs. 10 POKE 8195,0 loads the four higher order bits 
of the 12 bit address into address counter IC3 by placing the 
high order address value on data bus bits DO through D3 
and pulsing pin 11 of IC3 to a logic 0. 20 POKE 8192,0 loads 
the eight low order address bits into counters ICl and IC2 
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15 loads the 8 lower order bits of the address counter 


8193 
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8194 


13 transfers data from "programmable" EPROM to the VIC 20 
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1 2 Loads the 4 higher order bits of the address counters 
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8197 
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by placing the EPROM address value on the data bus and 
pulsing pin 11 of ICl and IC2 to a logic 0. To advance the 
counters, which increments the selected address, the 
following instructions are required: 
10 POKE 8197,0 
20 FOR I - TO 50: NEXT I 

POKE 8197,0 generates a device code pulse on pin 10 of the 
74LS138 (IC4). This low going pulse triggers a monostable 
multivibrator (IClO), which is configured to generate a 50ms 
high-going pulse. This 50ms pulse is required in the EPROM 
programming sequence which will be discussed later. The 
output of the monostable (pin 3, IClO) is connected, through 
an inverter, to the "up-count" input of ICl. If the 
READ/PROGRAM switch (SI, Figure 1) is in the READ 
position (open), the selected address will be advanced by one 
when the monostable times out, but no EPROM memory 
location will be programmed. However, if the 
READ/PROGRAM switch is in the PROGRAM (closed) 
position when the POKE 8197,0 instruction is executed, 
address location (decimal) on the programmable EPROM 
will be loaded with a before the address counter (ICl) is 



advanced. Details of this sequence will be discussed further 
in the explanation of the programming mode. 

The important thing to remember in our discussion thus 
far is that for the purpose of reading either EPROM, the 
READ/PROGRAM switch must be in the READ position. 
The second instruction 20 FOR I - TO 50: NEXT I is a 
software time delay to allow the monostable to time out 
before any other instructions are executed. Even though the 
50ms pulse is only used in the programming mode it is still 
generated in the read and verify modes to advance the 
counters. It is the trailing edge of this pulse that always 
advances the address counters and thus must be accounted 
for in all the modes of operation. 

The second basic function performed by the EPROM 
programmer is reading data from the "read only" EPROM. 
In order to do this, the memory address of where the read 
operation is to occur is loaded into the memory address 
counters as previously explained. Next, a memory read 
operation is performed by the VIC-20 which generates an 
input device code pulse on pin 11 of the device code pulse 
generator IC4. Pin 11 of IC4 is connected to the chip select 
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Figure 3: 2716 Read Timing. 



(CS) input of the read only 2716 (IC6). When the CS input 
(pin 20) is pulsed low (with pin 18 tied low and pin 21 held 
high) data flows from the memory location addressed on the 
EPROM into the VIC-20. Figiire 3 shows the timing diagram 
of the 2716 read operation. The following software is 
required to perform the read only EPROM read operation: 

10 POKE 8195,0 

20 POKE 8192,0 

30 A - PEEK(8196) 
The BASIC instructions in lines 10 and 20 set the memory 
address of where the read operation will occur. These two 
instructions have been previously explained. The instruction 
30 A-PEEK(8196) generates a device code pulse on pin 11 
of IC4 which inputs the data from the addressed memory 
location, and assigns the data to the variable name "A". 

The third basic function performed by the EPROM 
programmer, reading data from the programmable EPROM, 
is accomplished in exactly the same manner as reading from 
the read only EPROM. The only difference is that a device 
code pulse is generated on pin 13 of IC4 instead of pin 11 as 
in the case of the read only EPROM. Pin 13 of IC4 is 
connected to the CS input of the programmable EPROM (pin 
20, 1C5) and to the output enable (OE) of an octal tristate 
buffer (pin 1, IC8). Data flows out of this EPROM and 
through the buffer when pin 13 of the 74LS138 is pulsed low. 
For the read operation to be accomplished, pin 18 of the 
2716 must be at a logic and pin 21 at +5 volts. The 
software required to read data from the programmable 
EPROM is: 

10 POKE 8195,0 

20 POKE 8192,0 

30 A - PEEK(8194) 
The fourth and last function performed by the EPROM 
programmer is programming an EPROM. To enter the 
program mode, the READ/PROGRAM switch must be 
placed in the PROGRAM position. This applies + 25 volts to 
pin 21 of the EPROM (IC5), and configures the EPROM to 
be programmed. Be sure that the 25 volt supply is stable 
and at no time fluctuates higher than 26 volts. A voltage 
gfMter than 26 volts on pin 21 of the EPROM will 
immediately destroy the EPROM. Next, as was the case 
when reading the EPROMs, the memory address of where 
the data transfer is to take place must be loaded into the 
address counters. By applying an address to the EPROM, 
placing pin 21 at + 25 volts, and insuring that the CS input 
is at a logic 1, the EPROM is ready to be programmed. 
Applying a data byte on DO through D7 of the EPROM. and 
pulsing pin 18 (PD/PGM) to a logic 1 for 50ms completes the 
programming operation. The timing diagram for the 2716 



programming sequence is shown in Figure 4. The data is 
applied to the EPROM by the VIC-20 through a memory 
write operation to location 8197 (decimal). This memory 
write operation generates a device code pulse on pin 10 of 
IC4 which latches the outputted data byte into IC7 and 
triggers the monostable multivibrator (ICIO). The 
monostable applies a 50ms high-going pulse to pin 18 of the 
EPROM and programs the applied memory address with the 
data byte latched in IC7. The falling edge of the 50ms 
programming pulse automatically advances the counters and 
prepares the next memory address for programming. The 
following software is requfred to program address location 
with decimal value of 100: 

10 POKE 8195.0 

20 POKE 8192.0 

30 POKE 8197.100 

AppUcation Software for the VIC-20 EPROM 
Programmer 

The software requfred to read, verify, and program 2716 
EPROMs will be presented in the following discussion on 
application software. To perform an EPROM duplication, the 
contents of a previously programmed EPROM is transferred 
into the VIC-20's RAM memory. Here the data can be 
inspected and/or modified if desfred. The data is then 
transferred to a blank EPROM. and a verification is 
accomplished to ensure that no error occured in the data 
transfer. The following software reads the 2048 memory 
locations of a 2716 and places the data into the VIC-20's 
RAM memory between locations 5000 (decimal) and 
7048(decimal). Insure that the READ/PROGRAM switch is 
in the READ position, and that the EPROM to be read is 
inserted into the read only EPROM socket: 



"SET SWITCH TO' 
"READ POSITION" 

"HIT RETURN" 
'TO START" 



10 PRINT 

20 PRINT 

30 PRINT 

40 PRINT 

50 PRINT 

60 PRINT 

70 INPUT X 

80 POKE 8195,0 

90 POKE 8192,0 
100 FOR 1-5000 to 7048 
110A-PEEK(8196) 
120 POKE l,A 
130 POKE 8197,0 
140FORT-0to50:NEXTT 
150 NEXT I 

160 PRINT"READ COMPLETE" 
170 STOP 



/clear screen 

/ensure that 
/READ/PROGRAM 
/switcti is in 
/correct position 

/load high-order 74LS193 
/load low-order 74LS1 93 
/set 2048 RAM spaces 
/read EPROM 
/store value in RAM 
/advance counters 
/wait tor 50ms pulse 
/to read next location 
/prompt user 



•Do not enter comments in right hand column as part of 
program. 

Once the data is in RAM memory, the user can check the 
code to ensure that the correct 2716 is being duplicated, 
and/or make minor modifications to the code. Once satisfied 
with the data in RAM, the data is transferred to a blank 
EPROM which has been inserted into the programmable 
EPROM socket. Before the transfer Ukes place, the 
READ/PROGRAM switch must be placed in the 
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PROGRAM position. The following software loads the data 
which is in the VIC-20's RAM memory space, between 
address 5000 (decimal) and 7048 (decimal), into a 2716 
EPROM: 



200 PRINT "•■ 

210 PRINT"SET SWITCH TO' 

220 PRINT"PROGRAM POSITION" 

230 PRINT 

240 PRINT"HIT RETURN" 

250 PRINT-TO START ■ 

260 INPUT X 

270 POKE 8195,0 

280 POKE 8192,0 

290 FOR I - 5000 to 7048 

300A-PEEK(I) 

310 POKE 8197,A 

320F0RT-0to50:NEXTT 

330 NEXT I 

340 PRINT"PROGRAMMING COMPLETE 

350 STOP 



/Clear the screen 

/ensure ttiat 
/READ/PROGRAM 
/switch is in 
/correct position 

/load high-order 74LS1 93 
/load low-order 74LS1 93 
/set 2048 RAM spaces 
/read data from RAM 
/write data to EPROM 
/wait lor 50ms pulse 
/go read next location 
/prompt user 



When the programming is complete, you should run the 
following verification program to ensure an accurate 
EPROM copy: 



400 PRINT"" 

410 PRINT-SET SWITCH TO" 

420 PRINT-READ POSITION" 

430 PRINT 

440 PRINT-HIT RETURN" 

450 PRINT"T0 START" 

455 INPUT X 

460 POKE 8195,0 

470 POKE 8192,0 

480 FOR I - 5000 to 7048 

490A-PEEK(8194) 

500B-PEEK(I) 

510IFA<>eTHEN 570 

520 POKE 8197,0 

530FORT-0to50;NEXTT 

540 NEXT I 

550 PRINT"DUPLICATION GOOD' 

560 STOP 

570 PRINT-DUPLICATION BAD" 

580 PRINT-ERROR IN" 

590PRINT"ADDRESS ';! 



/clear the screen 

/ensure that 
/READ/PROGRAM 
/switch is in 
/correct position 

/load high-order 74LS193 
/load low-order 74LS1 93 
/set 2048 RAW spaces 
/read programmable EPROM 
/read data from RAM 
/it no match then stop 
/if match, advance counters 
/wait tor 50ms pulse 
/go do next comparison 
/prompt user 



/prompt user 



As mentioned in the introduction, EPROMs programmed 
by the VIC-20 EPROM programmer can receive their data 
from a number of sources. The only modifications necessary 
to input data from other sources would be between lines 80 
and 160 of the BASIC code. These lines of code move data 
from some source (another EPROM in the above case) and 
place the data in the VIC-20's RAM memory. Using the 
EPROM programmer for my own application, I was required 
to take data from the VIC-20's RS-232 interface port. The 
following software accomplishes a data transfer from the 
RS-232 serial port and places the data into RAM memory 
locations 5000 (decimal) through 7048 (decimal): 



80 OPEN 2,2,3 CHR$(163) 

2 Stop bits 
90 FOR I - 5000 to 7048 
100GET2,A$ 



• CHR»(160) /open the channel, 110 baud, 

/set 2048 RAM spaces 
/turn on receiver channel 



110 IF A$.-- THEN 100 

120A-PEEK(667) 

130 B-A-t- 7423 

140C-PEEK(B) 

150 POKE I, C 

155 NEXT I 



/Ignore a null 

/find serial byte in buffer 

/define buffer location 

/get data from serial port buffer 

/put data In RAM memory 

/go get next data byte 



yd 



Another possibility for entering data is through the VIC- 
20's keyboard. This is not practical for larger data bases, but 
in many cases the data is 
less than a few hundred 
bytes. For that amount of 
data the keyboard is not a 
bad option. The following 
software will load data 
into RAM memory starting 
at location 5000 (decimal), 
via the vic-20's keyboard: 

Enter an "S" to terminate the entry program 






Flgure 4: 2716 Program Timing. 

'woltage on pin 21 of Ihe 2716 musi tK * 25Volts 



80 PRINT '"• 

85 FOR I - 1 to 2048 

90 PRINT-ENTER DATA" 

95PRINT"BYTE";I 
100 INPUT A$ 

105IFA$-"S"THEN160 
110A-VAL(A$) 
115 J- U 5000 
120 POKE J,A 
125 PRINT -- 
130 NEXT I 

135 PRINT-NO MORE ROOM' 
140 PRINT-ON EPROM " 
145 STOP 



/clear the screen 

/input up to 2048 times 

/prompt user 

/to enter 

/data byte 

/enter S to stop 

/convert input string to a number 

/define RAM storage location 

/put data in RAM memory 

/clear the screen 

/go Input next data value 

/prompt user 



A Word About Bu8 Buffering 

My original VIC-20 EPROM programmer design did not 
have Data and Address bus buffers, but I encountered some 
problems when inserting and removing the EPROMs. When 
I inserted or installed the "read only" 2716 EPROM, the 
VIC-20 operating system would crash. I installed the 74 245 
data bus buffer and the 74LS367 address bus buffer and the 
problem disappeared. In general it is a good idea to buffer 
all of your interface projects. This ensures that you have 
good "drive" from your computer, and buffering isolates the 
CPU and other ICs in your computer from your circuit, 
which could avoid damage to the computer as a result of 
wiring errors. 

Programming 27328 On the VIC-20 EPROM 
Programmer 

So far only 2716 (2K by 8) EPROMs have been mentioned 
with reference to the VIC-20 EPROM programmer. The 
programmer can also program 2732 (4K by 8) EPROMs. 
There are only three pins which differ between the two 
EPROMs. These are pins 18, 20, and 21. Figure 5 shows the 
connection changes necessary to use the VIC-20 EPROM 
programmer with 2732 EPROMs. These connections can be 
hard wired to configure the EPROM programmer for 2732s 
only, or a 14 pin wire wrap socket can be placed on the 
EPROM programmer board and wired so that jumper wires 
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can be used to choose between programming 27169 and 
2732s. Using this method, personality modules can be 
constructed which plug into the 14 pin socket. These 
modules determine whether the programmer is configured 
for 2716 or 2732 EPROMs by providing the correct jumper 
wires across the 14 pin socket. Figure 6 shows how the 
socket is wired to achieve the EPROM selection using the 
personality modules. Also in Figure 6 are the wiring 
configurations necessary to construct both the 2716 and the 
2732 personality modules. The modules themselves are 
constructed from 14 pin DIP headers, with jumper wires 
soldered in place on the header to configure the module. 
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Figure 6: Personality Modules and Socket 



CoDBtruction of the VIC-20 EPROM Programmer 

The VIC-20 EPROM programmer can easily be 
constructed on a perforated Vectorboard equipped with 
edgeboard fingers. The edgeboard fingers must be double 
sided and the pin spacing must be 0.156 inches. The 
Vectorboard is standard equipment, and can be purchased 
from most electronic parts distributors. 



I used wire wrap techniques to construct the EPROM 
programmer. There are no critical wiring considerations, 
and the project took less than five hours to construct. A 
photograph of the VIC-20 EPROM programmer is shown in 
Figure 7, and a pin assignment of the VIC-20 expansion port 
is shown in Figure 8 to aid in construction of the 
programmer. 

It should be noted that an external 25 volt power supply 
is required to program the 2716 and 2732 EPROMs. 

The software routines used to program the 2716s will also 
work with the 2732s. The only changes required in the 
software routines are in the instructions which account for 
the 2716's 2048 memory locations. To program 2732s on the 
VIC-20 without expanding the VIC RAM memory, the 2732's 
4K memory should be considered as two 2K blocks. Each 2K 
block would be programmed separately, which would 
require two passes through the software routines. On the 
first pass the address counters should be loaded with a 
starting address of zero and the first 2K locations would be 
programmed the same as a 2716. On the second pass the 
address counters should be loaded with a starting address of 
2048 and the next 2K locations would be programmed. 

CoDclusion 

The software routines presented in this article are what I 
would consider utility routines. They make the VIC-20 
EPROM programmer work, but they are neither instructive 
nor "friendly" to the user. Providing only the required 
utility routines allows you to develop an "operating system" 
to suit your particular needs. 
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If you want to use the VIC-20 EPROM programmer as a 
general purpose programming tool for both 2716 and 2732 
EPROMs, I would suggest a "prompt and queue" operating 
system. By "prompt and queue" I mean that the computer 
prompts the user and asks the user what he/she would like 
to do. The user in turn enters the proper queue which 
instructs the computer to perform a specific task. This type 
of operating system can be implemented nicely with the use 
of menus. For example, you might have the VIC-20 ask the 
following question: 
WHICH TYPE OF EPROM DO 
YOU WISH TO CONSIDER? 

If you input "2716", the VIC-20 might print the following 
menu: 
WHAT FUNCTION DO YOU WISH TO PERFORM? 

1) EXAMINE CODE ON A 2716 EPROM 

2) PROGRAM A 2716 EPROM 
S) DUPLICATE A 2716 EPROM 

4; ENTER CODE THROUGH KEYBOARD 

5) ENTER CODE FROM TAPE 

6) ENTER CODE FROM RS232 PORT 

7) ENTER CODE FROM DISK 

8) QUIT 

INPUT YOUR SELECTION? 

This menu allows you to perform all the functions which are 
possible on the VIC-20 EPROM programmer. Selecting a 
desired function might result in another menu being printed 
which would help the user choose the proper parameters 
used in a utility routine. In addition to helping with 
parameters, the VIC-20 could instruct the user as to which 
"personality module" to use and when to insert it. Your 
imagination is your only limitation when designing an 
operating system for the VIC-20 EPROM programmer. Have 
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fun with it and drop us a line to let us know what you come 
up with. ■ 
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Multi-user 

A Column by E.G. Brooner 



CP/NET is Digital Research's answer to the 
networking problem. It is in some ways not a complete 
network (in fact, it is only the software for one), but it is 
probably the cheapest way for a clever computer user to 
"get into" networking. CP/NET can be thought of as an 
extension of CP/M and MP/M. It takes advantage of the 
existing features in these very popular operating systems. 
Using CP/NET is just like using either of its parent 
systems — all of the same commands are used along with a 
few new ones to take care of network communication tasks. 
Basing the network software on what is already there 
greatly simplifies the entire process. 

The latest brochure listed the cost of the CP/NET 
software at around $200 for each "workstation," which can 
be almost any micro equipment running CP/M. Actually, one 
station has to be MP/M equipped -there is no way around 
that restriction. And if only one station is so equipped, you 
really have something similar to a multiprocessor or a very 
good timesharing system. CP/NET becomes more "network- 
like" as more MP/M workstations are added. 

In talking about other milti-user systems, especially 
networks, we have made mention of the centrally located 
disk and printer peripherals that can be accessed by the 
secondary users. In network terminology these "intelligent" 
devices are referred to as servers; i.e., disk servers and 
print servers. A server is usually a dedicated 
microcomputer handling the communication to and from the 
peripherals, or between the peripherals and the 
workstations. 

In CP/NET, the server function is performed by part of 
the additional network software. The MP/M equipped micro, 
which must be part of any CP/NET, acts as a server for the 
rest of the network in addition to performing any other 
functions assigned to it. The MP/M equipped micro can 
accomodate up to a total of 16 users. If they are terminals, 
you have a time sharing system; if they are micros with 
their own processors, the system can be a network. 

Let's take a look, first, at MP/M. A time sharing system 
would consist of one micro running MP/M and some number 
of terminals sharing its one CPU and its memory, as well as 
the peripherals. You might find that as you add more than 
the first two or three terminals, the speed of each user 
begins to suffer, especially if all of them are quite busy. 

If you replace the terminals with individual complete 
micros, each running CP/M, the situation can be somewhat 
better. It will not be any better when they are working 
through or with the main computer, but if they were to 
disconnect themselves temporarily, they would have the 
ability to function independently. This is what happens in 
the simplest possible configuration of CP/NET. The 



replacement of terminals with complete computers is 
basically the dividing point between time sharing and 
networking. 

At this point the CP/NET resembles its more 
sophisticated brethren in that the users are capable of 
working by themselves when not accessing the central 
peripherals. In an ordinary MP/M system, the additional 
users have to share the same CPU and memory system as 
well as the peripherals. 

A CP/NET with only one shared MP/M server wiU display 
many desirable network features and lack some others such 
as a high speed communication system (communication is by 
way of ordinary I/O ports) or a sophisticated error-detection 
and correction capability. It can be favorably compared to a 
multi-processor system, since the users operate 
independently when not accessing the host system's 
facilities. 

More network features appear when more than one of the 
workstations is equipped with an MP/M operating system 
rather than ordinary CP/M. Two or more such installations 
can access each others' peripherals, while communication 
between one MP/M and one CP/M station is more of a one- 
way operation. However, the communication in either case 
is at the inherently slow speed of an I/O serial port, and you 
might have to write or alter part of the software to have the 
kind of communication you really want. 

How it Works 

Knowing CP/NET's terminology is important in 
understanding the system. Any MP/M equipped machine (or 
machines) rate the title of master and the CP/M 
workstations are called slaves. This fairly well describes 
their relationship as far as sharing facilities is concerned. 

Essential elements of any CP/M system are the BIOS (I/O 
system) and BDOS (disk operating system.) When we 
graduate to MP/M we find that the BIOS is replaced by an 
XIOS (extended I/O) to handle multiple users, and that the 
BDOS is augmented by an "eXtended" XBDOS. This is the 
part that handles the time sharing chores. Figure 1 shows 
the relationship of these elements to system memory and 
the rest of the MP/M system. The configuration shown here 
would permit several terminals to share the MP/M-eipiipped 
computer. An MP/M system would normally share a single 
computer with several terminals. 

CP/NET allows the slave users to be complete computers 
rather than simply terminals — thus, they are spared from 
having to all share the same CPU. The CP/NET opwating 
system is a logical extension of the elements just discassed. 
Figure 2 shows the added elements and their rtiative 
position in the CP/M system. One of these new elements is 
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the NDOS, or network system; another, the SNIOS is the 
slave I/O software. 

Notice now that the application program communicates 
directly with the NDOS; this is shown in flowchart form in 
Figure 3. The NDOS "decides" whether a particualr system 
call should be routed to the resident BDOS (as it ordinarily 
would be) or to the network, via the SNIOS. If the user has 
addressed one of his local peripherals, the I/O is handled by 
his internal CP/M system. If he has addressed a remote 
device, the I/O is routed to the network and thus to its 
ultimate destination. The slave user operates independently 
of the MP/M master except when accessing its peripherals. 

Using CP/NET 

If you're familiar with CPftA you already know about the 
software linkage of "physical" and "logical" devices; these 
include the CON: or console, and the LST: or printer, among 
others. You also have available, in CP/M, several disk drive 
assignments. These various devices can be reassigned 
(within limits) by commands from the console. 

CP/NET extends this capabQity. In CP/NET you can 
reassign some of the master's devices in a similar way. For 
example, NETWORK H: - C:(01) assigns disk drive H: of the 
master for use as drive C: by user number 1. Drive H: might 
be a single floppy or a segment of a shared hard disk. 
Similarly, a printer driven (served) by the master can be 
assigned to be the LST: device of one or more users. 
Following these assignments the user simply calls for drive 
C: or LST: just as he would if they were a physical part of 
his own installation. In a moment we'll look at how this is 
actually handled by the software. 

The access of a master facility may not be instantaneous, 
because of the sharing that might be taking place. These 
delays, which hopefully will not be excessive, are handled by 
a "queuing" arrangement in the master's network software. 
User requests line up and wait their turn, if necessary. 

Implementation 

There is some software modification to be made whenever 
a new CP/NET is placed in service. User and device 
assignments have to be made, to name the most important 
task. These assignments are entered into the software and 
become part of ttatus tables. These tables have to be 
accessed by the individual user operating systems, to guide 
the routing of communication from one point to another. 

Another important software task is the automatic 
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construction of "messages," within which the actual data or 
command (being transmitted from-here-to-there) is only one 
section. The source and destination addresses and some 
other control information are also appended. Figure 4 
outlines a typical CP/NET message. Remember that you 
don't have to put this message together -the system does it 
for you. The real "data," which may be just a CP/M 
command line, is all that the user has to provide. 

You might also wish to have some sort of customized 
hardware interface at each machine to permit the use of a 
communication protocol other than what is a part of your 
"normal" I/O ports. None of this should be very terrifying to 
experienced persons, but neither can the installation be 
considered just a "plug it in, turn it on" kind of operation. 
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Evaluation 

I must confess to having never used either MP/M or 
CP/NET, so this report is based on information released by 
Digital Research as well as reports found in other 
publications. It has been reported by others that 
implementing MP/M, either as a timesharing jystem or as 
part of CP/NET, is not a trivial task. 

Based on my own experience with CP/M, and the general 
reputation of Digital's products. I would expect the system 
to be all that is claimed, and perhaps more. One 
expectations would be that current revisions might differ 
from, and be superior to, the original release. The price is 
attractive. I would expect that any CP/M compatible 
software would work with either MP/M or the network, 
which could be a valuable asset if you are already using such 
software. 

My best guess is that "network" is stretching the term a 
bit if you compare this system to some of the more 
expensive ones such as Ethernet, but that it is a worthwhile 
compromise for the small-budget user of desktop computers. 
Because of rapid developments in networking technology, 
too, some of my source material might be obsolete by the 
time this column is printed. To be on the safe side, if you are 
interested, please research the matter in detail and make 
your own evaluation of whatever version is currently 
available. 

For more information on MP/M and CP/NET. contact 
Digital Research Inc., Pacific Grove. CA 93950. 
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Build a High-Resolution S-100 Graphics Board 

Part Three: Construction 



by Lance Rose, Technical Editor 



J,n the first two parts of this series, we described what is 
needed to display a video image, and discussed the present 
circuit in depth — now it's time to get down to the actual 
.construction details. 

Figure 1 shows a photograph of the front side of the 
graphics board. Figure 2 shows a view of the back side 
which should help suggest some wire routings. These are 
not all that critical and if you prefer a different routing, go 
ahead and use it. Figure 3 is a drawing of the front side of 
the circuit board identifying each of the ICs on it along with 
the pin #1 locations. 

The first obvious thing is that there are plenty of chips to 
find a place for, so there is no wasted space. Although the 
layout shown here is not the only possible one, I did 
experiment with several other variations and this one came 
out on top. The rationale behind the layout is as follows: The 
state ROMs and clock oscillator are all located near each 
other to minimize long connections. Most of the small 
LSTTL chips are also placed to minimize long connections 
and reduce clutter. The crystal is mounted near the top of 
the board to facilitate changing. Although this probably 
won't be a factor for you, during development I tried a 
couple of different crystals and wanted to be able to access 
it easily. Also, the crystal is mounted in a piece of socket cut 
from a DIP wire-wrap socket. This can be done with a small 
hacksaw or coping saw. Alternatively, you can solder it in if 
you're sure you won't have to change it. Personally, I am a 
fan of flexibility. 

The DIP switch for address selection is also at the top of 
the board where it can be reached when the board is in the 
card cage. Once again, if you know you'll be setting the 
switches once and never again, you can move it down. You 
can even go further and eliminate the switch and wire wrap 
the inputs to the open-collector NOR gates to either + 5V or 
ground. It saves one IC position but makes changing the 
address a bit of work. 

All the bus interface chips are mounted near the bottom 



of the board (near the bus, naturally). The address decoders 
and some of the other chips are in something of a 
compromise location. Since the RAM chips take up a lot of 
space, choosing a layout for them took quite a while. I tried 
layouts with the 24-pin sockets in a horizontal position but 
they didn't work out as efficiently. 

If you have had some experience in board layout or just 
want to strike out on your own, by all means do so. There 
may be other layouts that are a hair better but I think most 
of you will be quite satisfied with this one. 

You can see that the TO-3 type regulator takes up some 
room, but I'm a believer in adequate power supplies. I 
wouldn't feel good about using only a single TO-220 5-volt 
regulator even though on paper it has the same current 
capacity as the larger metal one. And two of the TO-220s 
take up as much space as one of the T0-3s when you include 
heat sinks for them, so.... 

The complete parts lists for the board is found in Table 1. 
As I stated in Part I of this series, you should be able to buy 
all the parts for around $200, or even a bit less since the 
price of 6116 RAM chips has come down a little since I 
bought mine. If you were to try using soldertail sockets 
instead of wire-wrap and solder all the connections, the price 
would be even lower. However, being conservative, I 
wouldn't recommend that approach. 

The basis of any layout you choose is, of course, the 
prototype board itself. There are a number of these to 
choose from. Some have pre-etched traces for power and 
ground, some have one pre-etched pad per hole, some have 
only an area for a voltage regulator (usually a TO-220) and 
some have nothing at all but the holes. The problem with 
any of those that have traces or pads laid out on them is 
that most of them assume you'll be using only 14 and 16-pin 
IC packages. Designs with a lot of 24-pin sockets don't seem 
to be able to take as much advantage of these pre-etched 
prototype boards. The good thing about them is that they 
usually have heavy traces for running power and ground 
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connections. 

I normally use the completely blank boards, not just 
because they are the least expensive but because they offer 
the most flexibility in layout. Using one of these does 
require that you pay due attention to providing adequate 
power and ground "busses". A single strand of 30 gauge 
wire-wrap wire is a bit marginal in my experience. All 
power and ground leads should be doubled if at all possible. 
Alternatively, you can use some heavier wire for the power 
and ground leads and connect all the sockets to these busses 
with short lengths of 30-gauge wire. This approach is 
probably the best but requires more soldering, at least until 
you get the power and ground leads laid out. If you choose 
to distribute power and ground with wire-wrap wire, try to 
lay them out in a grid pattern to approximate a ground 
plane. 

Another thing to watch is bypass capacitors. Be sure to 
use enough here. There are a lot of high-frequency signals 
running around, and one bypass cap per chip is not too 
much. This can be stretched a little in the RAM portion of 
the board since CMOS is more tolerant of noise. The RAM 
chips are crammed together pretty tightly and you might 
not be able to fit one in for each chip. 

Before beginning the actual construction, let me warn you 
about the 24-pin sockets. Some brands are sized such that 
they can be placed side-by-side on a board with no blank 
rows of holes between them. Others require a small gap. 
You'll have to obtain the former kind in order to get 
everything to fit on this board. I got mine from Jameco, but 
I'm sure they are available from other sources as well. 
These particular ones have a "CA" stamped on the top of 
the socket. I don't know if this is the brand name or not, but 
if you order sockets remotely, be sure to ask for ones that 
will fit side-by-side. This only applies to the 24-pin sockets. 
With the others, there is always at least one row's spacing 
between them. 

As a general procedure, I think it's best to begin by 
mounting the voltage regulator and tantalum electrolytics 
along with the connections to the S-100 8-volt and ground 
fingers. At the same time, you can do any other mechanical 
work necessary with a drill or file. The RCA phono jack 
shown here is mounted on a small L-bracket that has been 
drilled out to size. If you use a different type of connecter, 
do the appropriate work here so that when you get the 
sockets on the board you won't have to be drilling, sawing. 




filing and sanding around them. 

With a hefty TO-3 regulator you can afford to use one of 
the low-profile heat sinks. This will make it easier to get the 
finished board into your card cage. Once this is done, you 
can plug the board in and check out the regulator for proper 
voltage. 

Following this, my own habit is to place all the sockets on 
the board and fasten them down by connecting the power 
and ground leads to them. At the same time I solder in the 
bypass caps. Powering up at this point will detect any 
shorted caps and it will be easier to find them without all 
the signal leads running around the board. 

Perhaps I ought to say a word or two about color coding. 
I've seen projects built with only a single color of wire-wrap 
wire but debugging has to be more difficult that way. Even 
if all you have nearby is a Radio Shack store, you can still 
get 4 different colors - red, blue, yellow and white. If you're 
willing to mail order, you can get about another 4 or 5 
colors. That may be going overboard. I usually use red for 
power supply, blue for ground, yellow for address lines and 
white for data and signal lines (actually five colors would be 
just right). This is just a personal preference on my part and 
if you would rather use all one color, by all means go ahead. 
As long as you can find your way around the board, that's all 
that matters. 

After all the sockets are located on the board you can go 
ahead and start connecting the signal leads. The suggested 
order of wiring is as follows. 

First wire the oscillator circuit, which includes the 7404, 
the crystal, and the necessary resistors and capacitor. You 
can then power up and check for oscillation. You should be 
able to detect this with a reasonably good scope or logic 
probe. Once oscillation is verified, the next section to wire is 
the state machine. This includes the 2732 EPROMs, all the 
74LS193 counters, and two of the 74LS393s-U8 and U9. 
and the 74LS174. 

If you are going to program your own EPROMs, the 
program listing in Figure 5 is the one to use. It requires the 
use of either Digital Research's MAC* macro assembler or 
a recent version of Microsoft's M80 assembler. If you don't 
have either one of these or can't get access to one, you can 
either rewrite the program in BASIC or order a set of 
ROMs from Tke Computer Journal The price is $25 per pair 
preprogrammed. If you have the facilities for programming 
and would like a machine-readable copy of the program, we 
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can provide one on 8" single density CP/M for $15. This also 
includes the test program and sample use program whose 
listings appear in Figures 6 and 7 here. We may also be able 
to provide some 5.25" formats but you'll have to check with 
us and see if it's one that we can make. 

Once this is done and you have either programmed your 
own EPROMs or obtained them from us, you can plug the 
board in and look at the outputs of the 74LS174 to see if the 
timing is about what you would expect. This would mean 
blanking and sync outputs at approximately the horizontal 
sweep frequency and RAM counter reset (pin 15) once every 
1/60 second. If these outputs look about right, the state 
machine is probably working fine. 

Next go ahead and wire up the 74LS165 shift register and 
any necessary gates associated with it. Wire the transistor 
and the rest of the output circuit as well. Although I used a 
2N5450 transistor in my version, it was mostly because I 
happened to have a bunch of them in my junk box. Almost 
any small-signal transistor with a decent gain and 
bandwidth should work, so try using what you have handy. 

You can now connect the board to your video monitor for 
further troubleshooting. With the power on, the video 
screen should display a uniform bright raster with no 
tearing or lack of synchronization. If you can't get the image 
to lock in with the monitor's horizontal and vertical hold 
controls, something is out of whack. Try looking at the 
composite video output with an oscilloscope. The waveform 
should appear much as in Figure 2 in Part I of this series. 
Check both voltage levels and timing. The signal level can 
be off quite a bit and still work by adjusting the brightness 
and contrast accordingly, but the timing should be very 
close. If it isn't, stop and check all connections in the timing 



circuit U3-U5 as well as the state ROM address counters U8 
and U9. Also check the dot clock and byte clock outputs for 
proper frequency. 

Once you get a display that wUl lock in on the screen, go 
ahead and, using a clip lead, ground each of the parallel data 
inputs to the 74LS165 in turn. This should result in a series 
of thin, dark vertical lines in the bright field. Grounding two 
adjacent data inputs will produce wider dark lines. If this is 
what you get, so far so good. 

Next try wiring up the local RAM address counters U16 
and U17, buffers U18 and U19 and any necessary gates that 
go with them. Wire up at least one of the 6116 sockets, 
preferably one adjoining U18 or U19. This will let you 
display information fi-om the video RAM without having to 
have all the sockets wired. You should also wire up the 
address decoders U27, U28 and U29a and U20d, but only 
connect the chip select line for the one RAM socket you 
have in at the present. You'll also need U14b and U12d (you 
can leave pin 9 on the latter open for now). 

On powering up you should get an all-white (green) display 
except for a small area where the single 6116 is. In that area 
the screen should show random dots both on and off. In all 
likelihood, the pattern will be somewhat regular and 
probably look like alternating white and black bars about 8 
dots wide each. This is simply due to the power-up 
characteristics of the 6116 and has no other significance. 
There will be a few random areas anyway. If you don't get 
alternating bands, don't worry. The important thing is to 
identify at least a few features attributable to random bits. 

If things are working here, you're over the hump. Go 
ahead and make the connections for all the bus interface 
logic. This means wire everything else except the remaining 



VH I 



j; 



SI-S7 



Xl 






U3 



uH 



US' 



VI 



Ul 



» 

uis 






• 
UL 


• 

U7 



L/<? 



Ult 



Ull 



UXO 



Ug 



UIO 



» 
UIX 



UI3 



• 


* 
t/31 


i 
U3X 


• 


• 

L/3* 


• 
U3S 


• 

03L 


• 

037 


• 
U3i 




LI3') 


• 


• 

Ut-I 


• 

Ut^X. 


• 

0*3 


• 


• 

Ut-S 






• 


• 


• 


• 




t/J.7 

• 


• 


uxi 

• 


















• 




• 
Ul<i 


• 

UXI 




• 


• 




» 
UX'& 


• 

Uli 


L/l 


9 


UX 


i 









Figurs 3: Component layout tor board. 



The Compute' Journa' 15 



«-J ytn.Tr (/.j/ > - 



c-geuwo C^,*^ 



X 
X 



-}y OS li- 



IX 

_x 



t:! 



♦r 



cr-Cr 



x_ 



FIguri 4:Power Supply. 



RAM chips. Also, put in the DIP switch if you're going to 
use one. If you like you can place it in a socket, as I did. 
Double check all but the remaining RAM connections and 
you're ready for an actual test. 

Plug the board into your bus and power up. Of course if 
your machine won't operate at this point, you have a 
problem. Most likely you made a connection to a wrong bus 
pin or accidentally grounded a bus line or something of that 
nature. I have found that about 90% of all errors in 
prototype circuits can be found by visual inspection, 
checking the wiring against the schematic. Another thing 
you should be checking on a regular basis here is the output 
from the regulator. If it is more than about a quarter of a 
volt off, you probably should try another regulator. 

After you get the board in and the machine running, the 
easiest way to check the board out is from BASIC. The 
general procedure for writing a byte to the video RAM is as 
follows:! Assume the board is addressed at locations 100, 101, 
102 decimal) 

(1) Output the low byte of the desired video RAM address to 
port 100. 

(2) Output the high byte of the desired video RAM address 
to port 101. 

(3) Output the desired data byte to be placed in video RAM 
to port 102. 

You should be able to tell what addresses are active by 
which RAM socket you wired up. Outputting a byte of will 
make a dark line 8 dots wide appear at that location. A byte 
of 255 will make a bright line of the same size. Intermediate 
values will turn on or off all other possible combinations. If 
it doesn't appear to work right away here, double check to 
see that the single RAM chip you have wired up is at the 
address you think it is. If you're not sure, you can always go 
ahead and wire up all the rest of the RAM sockets and 
install the chips. However, that's a lot of connections and if 
you know you already have a working board and just have 
to mechanically run the wires, it seems to be psychologically 
easier. 

If you just can't get any effect from trying to write into 
the video RAM, you'll need a logic probe to do some tracing. 
Check for the WE* pulse on pin 21 of the RAM during the 
write operation. If you think it will help, you can disable the 
arbitration circuitry and allow constant access to the video 
RAM from the bus by temporarily removing the wires from 
pins 10 and 12 of UIO and grounding them. This should 
constantly select the bus address latches as the address 
generators for the RAM chips. Just don't forget to change 
this back after you find the problem. Make sure that U18 
and U19 are not being enabled at the same time as U21 and 
U22. Check for the usual things like bent-under pins on 



ci 

C2 

C3,C4 

C5-CI1 

Jl 

01 



R1,R2 

R3 

R4 

R5,R6 

R7-R14 

S1-S7 

Ul 

U2-U5 

U6,U7 

U8,U9.U16,U17 

UIO 

Ull 

U12 

U13 

U14 

U15 

U18,U19,U23,U24 

U20 

U21,U22 

U25,U26 

U27,U28 

U29 

U30-U48 



220 pf ceranic disk 

470 pf ceramic diek 

4.7 uf/25V tantalum electrolytic 

0.1 uf ceramic disX (bypass) 

RCA phono jack 

2II5450 or equivalent 

470 ohm, 1/4 watt 
100 ohm, 1/4 watt 
220 ohm, 1/4 watt 
150 ohm, 1/4 watt 
2.2 kohm, 1/4 watt 

7-pOBition DIP switch 

7404 hex inverter 

74LE193 presettable binary counter 

2732 4Klt8 EPROM 

74LS393 dual binary counter 

74LE174 he» D flip-flop 

74LS16S shift register 

74LS02 quad NOR gate 

74L£32 quad OR gate 

74LS08 quad AND gate 

7406 hex driver, open collector 

74LS244 octal buffer 

74LS00 quad NAND gate 

74LS374 Octal D flip-flop. 3-state 

74LS266 quad exclusive NOR, open collector 

74LS138 one of eight decoder 

74LS139 dual one of four decoder 

6116-4 2Kx8 CMOS RAM 

7805K 5 volt regulator, TO-3 

16 MHx crystal 

Table 1 : Parts List 



chips, bad chips (very unlikely) or wiring errors (much more 
likely). It's hard to give specific instructions here since there 
are so many variations. As I said above, most of my own 
errors have been due to accidentally leaving a connection 
out or making it to the wrong pin. When you're staring at 
about a thousand pins upside down and backwards, it's not 
too hard to do. 

After debugging the write portion, try reading the byte 
back. You can skip steps 1 and 2 above if you're accessing 
the same location. For step 3, input a byte from port 102 and 
see if it's the same as what you output. If not, use similar 
debugging techniques on the read portion of the bus 
interface logic. Note here that you can do either 1 or 2 
above without the other. You only need to change the 
portion of the address that is different from the last address 
accessed. 

The final step, once the board is working with a single 
chip, is to add the other RAMs. It just takes some time. 
With all the RAM chips plugged in, you're ready for final 
checkout. A simple test program in Microsoft BASIC is 
shown in Figure 6. It writes random bytes to random screen 
locations and then attempts to read them back. Make sure 
the DIP switch on the board is set for 100 decimal (64H) or 
else change the port numbers in the test program to 
coincide with what you have the switches set for. If an error 
is detected, the program reports it. When the program is 
running the screen should display a speckled random 
pattern that changes slowly, one speckle at a time. No hash 
should be seen in the display at all. If there is hash, suspect 
the interlock circuit that is supposed to keep the processor 
waiting during scan lines. Also check the wait state circuitry 
on the CPU board to make sure it's functioning properly. 
Most newer memories don't require any wait states so yours 



14 The Computer Jouma: 



Flgur« 5; Program for T.V. signal ROMs. 

2732 ROM prograir to generate TV waveforve 
U«ed for l,'0-mapped graphirB board 
Version oi 2/3/84 



; Equalising pulse a 



BLANK 
SYN^ 

COUNT 

WATT 

DISABL 

UKL 

BESET 

TtP 

VTBT 

LINL 

HSTHC 

LEFT 

HORIZ 

BIGHT 

EOPLS£ 

FINISH 

WKTOFF 

SWITCH 



ECU 

EOL 
ECU 
EOL 
EC'U 
EOL 
EOl) 
EOU 

tov 

ECU 
SET 
SET 

SET 
EOU 

EOL' 
ECU 
EOi: 



Low byte BOH 



eeeieeeep 

eejeeee.'T- 
ei»e«ee0t< 

] eBeeeeee 

2" 

lee 
iei6 

6B 
174 

t4e 

122 



el 



th dot clock 



TOP/ 2 
BSIIiC-l 

LEFT'] 
HOt- IZ/4- ! 
HOBlZ/4- 1 
HUBiZ/l-l 
KORIZ/4- 1 
RlGHT-1 



VERT/ 2 
BSYHr-J 

LEn-FlMS: 

FINIS!-- J 

WRTOFf- - 1 

SWITCfi-1 

HORIZ-] AMD 0FFH 

SWITC"--) 

fight-sw:tch-i 



rGenerate blanking ) e' 

;Genprate aync level 

rCount up RAM pointer 

;Cenerate wait state 

;Maintain wait state and disablp MWFlTt 

:KeeF wait, MWBITE disabled, uae RAM pointer 

;BeBet RAH pointer 

rScan lines in blanked top of fiame 

;Scen lines in view area 

:DotB in line 

iDots in horizontal sync pulse 

:Dot B in le(t border 

:DotB in view area 

;Dcte in rigbt border 

;DolB in egualizing pulse 

;DotB to finish current access 

;Dot6 to turn off MWRITE 

;DotB tc change itiul 1 1 r 1 eier inputs 



rBlanXed lines 



WPT<1FP- SWITCH-! 



MSYNf-1 rPlanKed half line 

L:NJ /r-HFYNC'-l AN! BKfH 



BEPT 


( 


;EqLjalirinq rulBe 


Di- 


LOPTJt-1 




np 


iiKt/;-fQrLSK- 


1 ANI^ BFFH 


EN DM 






bf;pt 


6 


;Vcrt ical retrare 


DF 


LlSf. . :-HSYNC -1 


ANT BFhH 


DB 


HSYNC - 3 




EHDK 






BEPT 


t 


;EquaJ izing pn i se 


DI- 


EOPI^t 1 




DP 


1 lHl/2'tOPLSt- 


1 AKi: eryh 



FOPLSl - 1 r ^■lJl 1 

LlNF-lCFLSl - 1 an: Blrl- 



HSYWr- 1 








LEKT- J 








H0FJ7 4-1 








HOR)7/'!- ! 








HORli", A- \ 








HOK5Z/4- 1 








RIGH-!-: 








VERT/: WiE 


blf 


inef 


in 


HEYN -1 








LEFn-I IKlPH-WRTOFK-SWlTCh 


1 




F1N1S1--1 








KPTOFF-1 








SV.lTCH-1 








HORIZ- ) ANF eFFH 








SWJTCh-1 








FlGHT-SV.:TrH-J 








t :Equ 


flllZl 


ng pu 


se 


EOPLSI-1 








L1IIE/2-E0PLSF-] AND 


BFFh 






i :Ver 


t iral 


retr 


9ce 


LlNE/2-HSy>J'-l ANT B 


^FH 






HSYNC-1 









may not be working and you won't have known it. If every 
byte comes back an error, something is wrong in the read 
portion of the bus interface logic. Check wiring. If only 
occasional errors occur, check for good grounding and power 
connections. Also, make sure there are enough O.luf bypass 
caps. 

When the board passes the GTEST program, you can then 
try out the sample plotting program included here in Figure 
7, also in Microsoft BASIC (but easily convertible to another 
BASIC). A screen menu lets you choose a variety of 
functions to test the board. The scale is assumed to be linear 
in both directions and the left, right, upper and lower limits 



»EPT S 

DB EOPLSl-1 

DB L1WE/2-E0PLSE-] AMD BFFH 

EM DM 

DB E0PL5t-l ;Bal f equal iting 1 ine 

DB L1NE/2-E0PLSE-1 AKL BFFH 



High b 


yte ROM 


BEPT 


TOP/ 2 :B 


DB 


BLA»K-t£YNC 


DP 


BLANK 


DB 


BLAKX 


DB 


BLANK 


DB 


BIANK 


DB 


BLANK 


DB 


BLANK 


EN DM 




DB 


ELAHK-tEY«C :V 


DB 


BLANK 


DB 


BLAWK*WA1T 


DE 


BLANK4D1EABI. 


DB 


BLANK-*l,OCl. 


t'F 


LOCI-t(H0RlZ-l )/25fc 


DB 


BLANK+DISABI 


DB 


BLANK 


REPT 


VEBT/2-1 


PP 


BLANK -tSYNC-KTOUNT 


LB 


BIANK 


LI' 


BLAN>-^WA1T 


DB 


BLANK*CISAB1 


DB 


BLANK -tLOCL 


TB 


i«:l-»(hobiz-i l/2Sf 


CB 


BLANK-triSABL 


DP 


ELANK> 



:Blanked lines at top oi firat field 



BLANK-tFYNC ;BlanKed half line 

BIANK* (LI NE/2-HSyNr-) )/25fc 

fc :Equal]ZJng pulses 

ELAN^ +SYNC 

BLANK-. (L1NF:/2-E0PLSE-] )/256 



f : Vert icel ret rac 

BLANK +SYNC-. ( LI NE/2-HEYNC- 1 )/2ifc 
BLANK 



5 rEquiilizinq pulses 

BlANK-tSYNC 

EIANK- ■, LIKf/?-EOPLSE-l i /2f>t 

FLANK *FYNr : Fu 1 1 eaua 1 a zing 1 ine 

BLAM-tFESET-- (L1KE-ECPLSE-! )/2Bfc 



TCP;' 2 

BLANK-* SYT*r 

FIANK 

BLANK 

[■LANK 

PLANK 

BLANK 

FIANK 



VrRT 



;BlanVed lines a- top o( second fjcld 
:(lncludt^s blar.ked half line) 



:Vi 



econd field 



PiJ*'..- *sym: -^c<,'UN^ 

blAKh 

ELAK*---! IKABI 

UJCl • iMO(J17-l )/25fc 
ElANK + nSABI. 
PLANK 



fc :Eoualirinq pulses 

BLANf -frSYNC 

BLANK4 1L1NE/2-E0PLEF-] ;/25fc 



f r Vert ica! retrace 

B1ANK->FYNC»(I.]NJ , 2-HSYN.-! )/2bfc 
FLANK 



S :EqualiEinqpuiBCB 

BlAN^ *SYNC 
PLANK-.(LlNF/2-E0PliF-l ) /2bt, 

ElANMSYNC :Half equalizing line 

BlA.NK-tKl.SFT-{LIKE/2-EC^'I Sh-1 )/256 



can be changed with the "Set Limits" option. After that you 
can set an individual point, draw a straight line, an arc or a 
sine curve (arguments in degrees). 

The program is designed mostly for fooling around and as 
an example of how to use the facilities of the graphics board. 
The painful slowness of BASIC is amply evident here. Any 
truly useful graphics programs simply must be written in 
assembly language to operate with any kind of reasonable 
speed. CompUed BASIC or FORTRAN are improvements 
but still not as good as assembly. If you aren't doing at least 
some assembly language programming yet. this may be the 
impetus you need. 
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Rgurt 6: BASIC test program. 



!••« A^ItPr(38399l«RMr) 
use OUT !•) . lKTl*/2ifc) 

i«3e r%>=2ifc»RNC Hor 2ib 

l»4fl OUT ]e3,D%:Ct-INP(ie2) 
)»5e IF r%-E% THLS l»«t 
1M>* A&<'HE>$tA) 

l»7e IF LCWtAS)<4 THEN AS« ■»■♦*$ lOOTO 1»7» 
IPee D5»MEX5(Dt):IF LEHIDS)-! THFB D$-"i'-»D$ 
1>9« ES-HEX5(E»):JF LEHfES)-! WEH E5-"«"*ES 
ll«e PBIKT "ERFOP AT "AS;". •:D$i" HEAC AS 'jES 
111* GOTO 1MP> 



Rgura 7: BASIC program to draw some shapes with the board. 

1M« REM CEHKt I/O POUT UDDRESSES 

1010 P#-10e!P]-Pe-tl :P2»P«*2 

1I20 HEB Srr DEr»UI,T LIMITS FOR SCREE" 

!•]• XI— 1.33333 :X9.1. 33333 :Yl.-l:y9- 1 

1H< REM CLEAIi SCREEN. DISPLAY MENU AND INPUT ^'"„„,„ ^,„.. 

ia» PRINT CKPS(27)r-« in CLEAR SCREEN" : PRINT (2) REVERSE VIDEO 

IKt PRINT ■ (3) SET P01in-;PBINT " Kl DRAM LlHE" 

1«7» PRINT - (5) DRAW ABC": PRINT • (6) SET LIMITS" 

laBB PRINT ■ (7) LOAD SCREEN ': PR I NT " (B) SAVE SCREEN 

!»• PRINT • (9) DRAW SINE CURVE", PRINT -(IBI EXIT" : PRINT : INPUT OrPRlNT 

MM RBI EXECUTE PROPER SUBROUTINE ANb THEN RETURN TO MENU 

lue OK GOSUI- 114».in«,13e«.lJ7t,137«.145«,148«,155t,Itie,H>ie 

112* GOTO IBbP 

1130 RE- CLEtp SCREEN 

1140 FOP HJ-0 TO 149:OUT ri,m:rOR L«-e TO 255 

1150 CV. t'0.1-«:Ol': F2,0:NEXT L%:NEX7 H%!RETURN 

1160 FIH f.[.tRSl VIDEO TOGGLE 

1170 F' ^ H»-P TC 149tOUT PJ.HliFCP L»-0 TO 255:OUT P0 . H 

IIB0 OUT ri.NOT INP;P2, AM- 255iNCXT L«:NEXT H»:PETURK 

1190 REP SIT A POINT ON THE SCREEN 

1200 INPUT "COORDINATEEJX, Y ) : '.X.Y 

1210 IF X.>1 OP X>X9 Ot Y.Yl OP Y>Y9 TBEK RETURU 

1220 HI-(X-X1 :/(X9-Xl)'639 

123P v*^(Y-Y9,/(Yl-Y9)*479:f«=V*'b0MH»\b:B = » (H* "^Or t) 
1240 OUT PP,H-lNTIM'256)'25t:OlT PI . I NT I M /25t ) 

1250 OUT f: iHr;r2j on b:Return 

12feP RE?- DFA*. LINE 

1270 INPl-T "STAPTING POINTIX.Y); -,X2.Y2 

128? INrUI "ENI :NG POINTIX.Y): ".XB.Yfc 

1290 CX.Xfc-XJ:rY.Yf-Y2:IF DX-P ANF PY-f THEN X 

1300 ir DX.>0 THIN E-DY/DX ELSE S.0:OOTC I 34^ 

1310 IF E'lX9-xn'479/(Y9-Yl I t39>) THEN E-!.f:GOTO 

1320 FCf X.XJ T^ XP ETtr- EGMXh-X2)'(X9-XU/12^B 

1330 Y.Y2*'X-X2)»S:C.OSUB 1210:NrXT X r RFTUBN 

1340 rcf l-YJ TC ye ETET EGN(Y6-Y2)'IY9-Y1 )/95e 

1350 X.X2'IY-Y2!'£:C0SUB 1210:NEXT Y : RETURN 

1360 FF^. DRAW APC 

1370 INPirr "CENTERtX.Yl : ".XC.YC 

1360 INI'-T "RArUIS: ■ ,R 

1390 INPL- TEGREt ilf 'TE ( PFG IN . ENO : ",AJ.a: 

I4PPA)=t;'.P]74 53?;Ar=A?*.ei^4533 

14JP 6. X--XJ ),t3S:lt (YV-Yl )/«7^.S THKN ■- ■ I Y9 - Y 1 , /« 7 <> 

14iP t.t; ?"R):Frf A"A1 TO A2 ETFP tGNlA?-Al)*S 

I43r >.PV SIX *Xr:Y.FVi-INII. »!r:GOSll! :2ie:NE>- « : PETUEN 

J440 Ft- FF" l.IF-ITS 

14'0 ^t^i'll .-CPI70N1X. LIMITS: ".Xl.XO 

14tP in;;-: •«!.-;■..■; Licni; -. W , Y9:RETUkN 

14;P NEM :OAr SCREEN FROM FI1.E 

14H' IKE.- Hi: NAI-! : ' .Fi:OPtN " B ' , 1 . F5 : FI ELF I 1 , 1 28 AE PS 

i4^e FOF F*=P Tt )49:0UT P1,HI;GET #J 

1501* F-i » = F T 3:~:0l'" PP.HrOU" F2 , A5C ( M : PF ( F E . H-t 1 , 1 1 ) 

1510 NEX^HrGFT ,1:F0R L1-12F TO 255:OUT Pe.H 

1520 CL- 1 i.AErit-irSlrS.U-UT. 1 )):NEX: LtrNEX- HI 

1530 CbOSF li:RETURN 

1540 RE- EXVE ECRFET- IN FILF 

1550 INPl- "FILE NAME: -.EFtOPEN " P " , 1 , FS : F I El T |l,12t AS DS 

1560 rtr ffr -.- 149:0U-F P1,H%:F0F H-l TC 12f:OUT P0,L«-1 

1570 »ir; F;,:> 1 ).CHRS;INrir2)):NEXT L«:PU1 11 

15eP FOF ;>=. Tf 12e:Ol'F P0,mi27;MID;(P6.I.l,Il-CHR?(lNP(P2)) 

1590 NEX- l.»;rUT #1:NEXT H* t CLOSE : RETURN 

1600 RE- PRAN SINF CUE VI 

16J0 ]Ni -: -XPGUMENTlFIClN.ENE.STEr ) ; ■,X2.X8,EX .,„,,„. 

1620 E, X.X^ T. Xt STEP OX : Y-SI N i X/ 57 . 2956 ) :GOSLb 12I0:NEXT X;RETURN 

1630 ENF 



MicroMotion 



MasterFORTH 

It's here - the next generation 
of MicroMotion Forth. 



-Y 2: GOTO I21P 



i340 



If you have gone this far and actually built the board, you 
probably had some ideas of what you wanted to use it for. 
Some of the things I wanted to do were to plot 3- 
dimensional figures, plot orbital data from my astronomy 
programs, generate Fourier waveforms and use it to display 
alphanumeric data in any one of a number of character fonts. 
Since the board is programmable on the dot level, you can 
make up characters in any shape you like (APL, Chinese, 
Arabic. Hebrew, Greek, etc.) You can do proportional 
spacing. You can plot in recUngular or polar coordinates. Its 
uses are limited only by your imagination. 

Although this concludes the series of construction articles 
on this board, there may be other articles on specific 
applications in the future if interest warrants it. W«'d like 
to hear your views on it. If you build the board, we'd also 
like to hear your difficulties, if any, and your reactions to 
the corrpieted product. ■ 



• Meets all provisions, extensions and experimental 
proposals of the FORTH-83 International Standard. 

• Uses ttie host operating system fliestrvxrture (APPLE 
DOS 3.3 & CP/M 2x). 

• Built-in micro-assernb)erwi1tir»urrieric local labels 

• Afullsaeen editor Isprovidedwtiich Includes 16 X 
64 format, can push & pop more ttxan one lir>e, 
user definable controls, upper/lower case key- 
txxjrd entry, A COPY utility moves screens vi/lthin & 
lDetv>«en lir^s. line stack, redefirxable control 
keys, and search & replace commands 

• Includes all file primitives described in Kemigan 
and Plaugefs Software Tools. 

• The irput and output streams are fully redirectable. 

• The editor, assembler and screen copy utilities are 
provided as relocatable object modules. They 
are brought into the dictionary on demand and 
may be released viflth a single command 

• Many l<ey nucleus commar>ds are vectored Error 
handling, number parsing, keytxxard translation 
and so on can be redefined as needed by user 
programs They are automatically returned to 
their previous definitions when the program is 
forgotten. 

• The string-handling package is ttte finest and 
most complete available 

• A listing of the nucleus is provided as part ot the 
documentation, 

• The language implementation exactly matches 
the one described in FORTH TOOLS, by Anderson 
& Tracy This 200 page tutorial and reference 
manual is included with IVIasterFORTI-i 

• Floating Point & HII?ES options available 

• Available for APPLE ll/il+/lle & CP/f^ 2.x users 

• MastetfORTH - S100 00. FP & HiRES-S40.00 each 
(less 25% for FP & HIRES) 

• Publications 

• FORTH TOOLS - S20.00 

• 83 International Standard - SI 5.00 

• FORTH-83 Source Listing 6502, 8080, 8086 - 
S20.00 each, 




Contact 

MicroMotion 

12077 Wilshire Blvd., Ste, 506 

Los Angeles, CA 90025 

(213) 821-4340 




HB-0100 Buss strip 

Each buss strip contain: 
groups of labeled contact 
points 125 per group) pro- 
viding multipoint distribu- 
tion for Vcc, ground and 
signal paths. When inter- 
connected, HB-0100's can 
simulate Micro-Processor's 
data or address busses 
simplifying ROM, RAM, 
UART, etc. to processor 
interconnects 

Competition Price: $3.00! 

25 



$9: 

HB-0100 ^ 




HB-1000 
Socket 



With HANDY sockets, 
breadboardingiseasy 
because you always know 
where you're at. Each group 
Df 5 contacts is labeled from 
-64 and each position within a 
IS labeled from a-j With 64 
of 5 contacts each you have 
then enough room for Infield 
ab mock-ups that always come 
when you least expect them. 

Competition Price: $12.50! 

95 



groups 



$Q! 

HB-1000 ^ 



HB-1210 

One socket and one buss strip 
with self-adhesive backing and 
metal ground plate. 
Big nine 14-pin DIP capacity . 

Competition Price: $18.50! / 

95 




HB-1110 

One socket and two buss strips 
with self-adhesive backing and 
metal ground plate 
Big nine 14-pin DIP capacity 

Competition Price: $15.49! 

95 



$11 

HB-1110 I I 



HB-2112 

A compact breadboard ideal for beginners, students, professionals and hobbyists. It's 

quick and easy to use and immediately becomes the most useful tool on your 

workbench. Includes;' 2 sockets • 1 buss strip 

' 2 binding posts and is mounted on an 8.7"x5.4" HB-2112 

aluminum ground plate, 18 14-Pin DIP capacity. 



$24 



HB-2313 



Holds enough IC s to meet any quick-fix 
situation Includes: "2 sockets 

• 3 buss strips .3 binding posts 
and is mounted on an 8.7"x5 9" aluminum 
ground plate. 18 14-Pin DIP capacity 

Competition Price: $51 .50! 



HB-3514 

Ideal for light industrial as well as secondary 
level educational and hobbyist experimentation. 
Includes: -3 sockets 

•5 buss strips •4 binding posts 
and IS mounted on a 9.4"x7.7" aluminum 
ground plate. 27 14-Pin DIP capacity 

Competition Price: $66.00! 



HB-4714 




Largest HANDY breadboard available today Complete PCB or even 

system mock-ups can easily fit on this breadboard. This high capacity 

heavy duty board is a must for industrial users where time is money 

. . .Great for advanced educational and hobbyist applications. 

Includes: '4 sockets • 7 buss strips '4 binding posts 

and IS mounted on a 10.3"x9.5" aluminum ground plate. 

Giant 36 14-Pin DIP capacity Competition Price: $89.00! 




Malt Ordtri: Please add $3 (Canada & tnt'i add S5) 

to cover cost ot shipping, handling 
Chargt Cards: (Mm S^b\ Please include Acct Nc . Exp Date. 

Bank No (M.'C only) and you' signature 
Chackt: Drawn in U S Dollars on U S banks only 
Conn RaaldenU: Add 7'/;% Sales Tax Sorryi No C O D orders 



Toorder.caM 1-800-34-HANDY 
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1^ ...charge with VISA, MasterCard or American Express 
' All Items off-the-shelf for Immediate Shipment! 

a division of RSP Electronics Corp. 

7 Business Parl< Drive • P.O. Box 699 • Branford, CT 06405 • (203) 488-6603 • TWX: (910) 997-0684 

Easy Link l^ail Box: 62537580 • CompuServe: 71346, 1070 

U.S and Canadian Distributor inquiries welcomed 



SYSTEM INTEGRATION 

Part Three: CP/M 3.0 

by Bill Kibler 
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In the first part of this series, we discussed factors to 
keep in mind when choosing components for system 
integration. In part two we looked at how SDSystems 
V.ersafloppy II was set up to run CP/M 2.2. 1 hope that most 
readers will have at least a 2.2 system running at this stage. 
If you have not yet used a 2.2 system, a complete reading of 
this article and other books will be necessary before 
considering CP/M 3.0. To help the novice and weekend 
hacker, let's first review what a 2.2 system does. 

CP/M 2.2 

CP/M is the interface between the hardware of your 
individual system and the generic types of software you will 
run. This program, known as an operating system, provides 
standard interfaces in two directions, one to transient 
programs and one to fixed hardware. CP/M advanced 
through many variations and stabUized for some time at 
version 2.2. This version is intended to run on an 8080 or 
Z80 CPU with 64K of memory, using fixed peripherals for 
1/0. An assembler, a debugger, an editor, and several other 
utilities are provided with the purchase of CP/M. This entire 
operating system makes it possible to change, modify, and 
generate new operating systems, in addition to running 
purchased programs with few problems. 
' The ins and outs of 2.2 are well known, and for those 
looking for more knowledge, your local computer store has 
many books on the subject. 2.2's structure is extremely 
straightforward. The relationship between the three 
modules that make up the program are fairly easy to 
explain. The CCP is the command processor and handles 
communications with the operator while in the system mode 
(not running any generic programs). The BEKDS (basic disk 
operating system) is the next module, and does most of the 
work. It works with running programs by the use ol function 
calls. The function calls are separate routines that together 
form the BDOS and allow canned programs to operate on 
different hardware. The BDOS takes a function call and 
talks to the next module, the BIOS (basic in/out system) as 
many times as necessary to make the hardware perform the 
requested function. 

2.2 has been around for so long now that other products 
are available that can enhance or replace all or portions of 
CP/M. With the books and software base avaUable, this 
operating system has little equal and allows me to 
recommend it without question as the choice of hackers. 
However, like most manufacturers, DRI (Digital Research 
Inc.) felt that an improved version of CP/M that 
incorporated most of the enhancements would allow them to 
take back control of their product. An improved version 
would also present an opportunity to work out the 



incompatibilities between 2.2 and DRI's multiuser operating 
system, MP/M. The cost of memory has decreased in 
quantum leaps, reducing the expense of having more than 
64K, and a system was needed that could make use of this 
cheap memory. So CP/M 3.0 was born. 

CP/M 3.0 

CP/M 3.0 or "PLUS," as it is sometimes called, is little 
different from 2.2. It is still the operating interface between 
the hardware and software, but with some new wrinkles. 
Memory can now be in multiple banks, outputs from 
programs can be changed or redirected, additions to the 
operating system can be created and tacked on, there are 
help programs and command line editing, and lastly, the 
system is supposed to be faster. What has been lost is a 
simple BIOS program and a lot of disk space. Although the 
gains may seem to outweigh the losses, closer investigation 
is needed. 

To utUize CP/M 3.0 more fully you will need more than 
one bank of memory. In the non-banked mode most of the 
enhancements are lost.as well as part of the transient 
program area (TPA). Current programs require up to 56K of 
temporary program RAM to run, and the non-banked TPA 
of 50 or 51K may not work. Once the BIOS has been 
generated for banked operation the TPA expands to over 
60K, which can be more than most 2.2 versions. The extra 
banks contain the larger BDOS, a copy of the CCP program 
(3.0 CCP is a transient program and not resident like 2.2), 
and data buffers. Higher operating speeds are possible for 
programs that use high disk access by locating the most 
highly and currently used sectors in the disk buffers (other 
banks). These buffers are assigned and managed by the 
BDOS and are not controlled in any way by the operator. 

Inputs and outputs are normally assigned through fixed 
BIOS definitions or routines. In 3.0, tables of I/O types and 
requirements are maintained, which allow the system 
configuration to be changed without rewritting the BIOS. 
This operator freedom of choice is made at the expense of 
memory (banked RAM) and speed (the whole table is 
scanned for each output of a character). 2.2 has an I/O byte 
that has now been expanded to several bytes to take into 
consideration the different possible ways of redirecting the 
data flow. A new program type, the RSX module, has been 
added. This program technique is helpful for those who want 
to add some special function that the BEKDS doesn't 
currently support. The new module is put below the BDOS 
and the inputs to the BDOS are redirected through it. In 2.2 
this was not possible except for enhancements to the BIOS 
routines as is done in RAM DRIVE modifications. 

The banked version allows the command line to be edited 
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instead of completely rewritten as is necessary with 2.2. 
This is made possible by larger command line buffers and 
the addition of more control functions to the CCP. HELP 
programs, although listed as a feature, are really not much 
more than the CPMUG or SIG/M version of HELP.COM. 
This disk program has help files that explain parts of the 
operating system's syntax usage. The help files are usually 
one line statements which tell what form the command must 
take to do the named function. These HELPs are in no way 
to be considered "tutorials," but are simply quick reference 
"cards." As for speed, the system can take longer to boot (it 
must load more information in different banks) but once 
booted, should require less disk access (the slowest part of 
the operation) and result in faster operations. The 
controlling factor, however, is still the speed of disk reading 
and writing, — if the information is not in a disk buffer area, 
it must be loaded into a buffer and then into the TPA. 
Depending on the type and nature of the programs, this 
buffering can be faster than 2.2. Also, for warm boots, the 
CCP is reloaded from a bank and not from the disk as is 
done in 2.2. 

The Implementation 

With the brief introduction out of the way, it is now time 
to "bite the bullet" and get to the "how-to" part. A word of 
caution is needed for those who found the previous 
discussions somewhat confusing; don't try to implement 
3.0 -buy it already done or get 2.2 first. Writing a banked 
BIOS and deciphering the DRI manuals is not for the novice 
programmer. In November of 1983, DRI changed its support 
policy to match that of most other big time software houses, 
mainly, no FREE support. They now charge a $250 yearly 
subscription fee to get in-depth information on their 
programs. Anything not covered in their manuals (and there 
is a lot not covered) must be explained through your own 
efforts or by a member of the subscription service. 

The first confusing topic is the many subroutines (see the 
listing for what is on DRI's disk). CP/M 3.0 is composed of 
many macro files (these are short assembly listings) that will 
be linked together to form the complete program. To make 
things worse for those doing the SDSystems 
implementation, they have their own version of these same 
programs for their hardware. SD's hardware is the SBC 300, 
and unfortunately, their programs are so hardware 
dependent that they are useless to anyone who does not own 
the defined hardware. The absence of the ASM files of the 
FLPDRVR and MOVE routines add to the problem. What 
this leaves for the programmer is the original DRI files and 
the disk controller routines from the SD VFII manual for 
generating a running system. On closer examination, I have 
found that the DRI files, with modifications, are a good 
source for a running system. Time has not permitted me to 
fully explore the use of DRI's files directly, but those who 
feel lost should consider starting there. I did use the 
BIOSKRNL and the 2.2 BIOS routines as the disk file, and 
was able to make it work in a non-banked mode. The manual 
indicates that a 3.0 BIOS can be made from a 2.2 BIOS, but 
it also says that two modules are supposed to be the root 



modules and should not be changed. A 2.2 BIOS will work 
for a non-banked system with some major changes, and the 
root BIOS is the starting point for the banked version. The 
SCB module adds more trouble due to the equates and 
vagueness. This macro has an equate of OFEOO hex, which 
would make you think that this is the exact address it will 
end up at. Wrong. Hidden in one line of the GENC7i»M 
discussion is a statement which points out that GENCPM 
will relocate "FE" locations into the BDOS and link the 
other references to them. If you check after GENCPMing, 
you will find this list of values located directly before the 
beginning of the BIOS (the last bytes of the BDOS). 

While covering linking of modules, you ahould check the 
listing; I have shown the terminal dialog for the necessary 
generations. CPMLDR is the program that loads the system, 
as it is a separate file listed in the directory. The BIOS 
portion needed for CPMLDR can be the same BIOS as used 
in the full system, just take care that BOOT is a RETurn if 
all the initialization has been done. The order of events is 
not well explained in the manual, but the loader will call the 
boot entry of the LDRBIOS first, then start loading and 
displaying data. While debuggmg my BIOS, I used the print 
message routine to help tell me at what point it would go 
into never-never land. The use of statements like "now 
reloading CCP" would tell me that I was in the warm boot 
routine and not the cold boot. Make it a point to read the 
discussion of "debugging CP/M" in the "systems guide," and 
thoroughly review the programmer's guide. Many of the 
necessary facts are spread out over many headings and 
books, making it hard to keep track of them. 

In last month's article I listed a BIOS routine and 
mentioned a similar one in SIG'M 26. Both of these 2.2 
BIOSs will use the addresses shown for storing disk data 
(these are the original addresses chosen by SD in DDBIOS 
listing). These addresses are in the page area, 040 hex to 
07F hex, and must be the same in all three programs 
(monitor, BOOT, BIOS). Two problems of 3.0 demand that 
they be relocated; first, 050 hex is the location of several file 
control blocks. Banked operation will require that certain 
stacks, buffers and disk values be located in the fixed 
portion of memory. These locations can be above the PROM 
when it is located at FOOh or just below it if an F800h PROM 
is chosen. GENCPM asks for the last free space of memory, 
80 any location could be used and GENCPM will move the 
system to it. 

The fixed memory locations will cause some problems 
because the write and read routines would normally get 
their data from the SCB files (which are public) and not from 
the memory locations that SD uses. For PROMS that have 
been written before understanding this problem, new 
routines will be needed to read the SCB data and then fill 
the monitor's buffer location for that data. A lot of these 
special problems arise from trying to keep the PROM in 
memory and fit CP/M around those parameters. Using a 
parallel port to turn the PROM on and off could make life 
simpler. Here's how; simply modify the boot loader routine 
so that the BIOS is complete and used for all operations 
(don't call any PROM entries - include the disk portion in 
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the BIOS). Now make the BOOT routine output to your port 
and turn off the PROM. The RETurn instruction jumps back 
to the CP/M 3.0 loader which loads the system file into 
upper memory. A master reset will always put you into the 
monitor if reset forces the parallel port back to the normal 
state. These steps will also solve the problem of clashing 
memory usage by removing the PROM and allowing buffers 
to be in the BIOS. However, any of SD's older programs 
that called the PROM BIOS entry points directly (format) 
will not work. 

It can be rather hard to determine what procedure to 
follow first in setting up the system. If using DRI's 
programs, an attempt to bring up the banked unit first may 
not be too foolish. Non-banked operation with the PROM 
wiU be easier through the simpler routines (calls to PROM) 
but will be more confusing due to memory conflicts. A non- 
banked non-PROM system will require more programming, 
and will also demand that the PROM phantom operation be 
set up. For system integrators this is normal; considerable 
time must be spent deciding on the trade-offs of system 
configurations. Try and understand your limits in both time 
and skill, and study what must be done. After examining the 
problems at length, experiment with several of the solutions 
to discover further problems that you may have missed. The 
SCB relationship is one that is hard to understand, and is 
just the kind of problem that haunts beginning 
programmers. I found the DRI information on the SCB to be 
rather short and confusing. It is not clear whether the 
source of data is the SCB or the called routines in the BIOS. 
I believe it to be the latter with the SCB used as a reference 
data source. 

Relations and Assemblers 

The relationship between modules is confusing at first, 
and will require several practice assemblies. First, assemble 
a new BIOS unit. Using RMAC (A> RMAC BIOS.ASM), 
find any errors and correct them. Next, assemble the 
modules (if there are any) and link them. Remember that the 
order of linking is controlled by the order of the entry line. 
In other words, if BOOT is listed before BIOS, it becomes 
the main program instead of BIOS (as it should be). 
Generally speaking, only the major program need be first. 
The others are called from the main and need not be in any 
order after that, except that the SCB is usually last (and 
must be a separate file for GENCPM to link properly). 
Check the listing for more information on this topic. Public 
and external items need to be marked as such and declared 
in the beginning of the file. To find out if a declaration was 
missed, assemble the file and then link it; undeclared items 
wiU be shown as errors in the linking and will send you 
looking for them. It is best to use many short routines in 
programming, as it is easier to link routines than to handle 
excessively large files. At first, however, and if the shorter 
BIOS that calls the PROM is used, the simplest method may 
be to include the needed routines with a word processor. To 
boot from a 2.2 system, a CPMLDR.COM file is used. This is 
called like any COM file and will then load the CP/M system 
files into memory. Later, the LDR files are put on system 
tracks and called through the monitor boot command. The 



loader will need to be linked with an [LlOO] option to make a 
COM file for use at lOOh. The BIOS is linked with the BOOT 
and SCB (CHARIO, FLPDRVR and others if needed) using 
the [B] switch to form an SPR file. This file will then be 
linked again by GENCPM to form the system files. The 
symbols or links that are established between the BDOS and 
the BIOS are not shown (normally a printed statement is 
displayed after linking). 

The procedure will be to write or change the BIOS, 
assemble it, link it. GENCPM, run CPMLDR, and then test 
it. Once a working CPMLDR is obtained, it can be used ever 
after, even though the BIOS may have many major changes. 
The system files contain a header entry that instructs the 
loader where to put the system. At this point it is up to you 
to keep at it untU the system works. 

Review 

These three articles are in no way a complete discussion 
of system integration or of what it takes to make advanced 
programmers out of novice hackers. I started out trying to 
cover it all, only to find that "all" would take many books. 
To even summarize what I have learned about the system 
and CP/M 3.0 is difficult. Documentation is still the most 
important aspect of any system. DRI has improved their 
documentation somewhat. Since I had not paid the $250 for 
professional help. I was unable to uncover all of the 
relationships within CP/M 3.0. I leave some of that for the 
reader, both as a challenge, and as a possibility for future 
articles for The Computer Journal. 

I still find the Versafloppy 11/696 to be a good product 
while operating under CP/M 2.2. However, the manual and 
documentation for implementing 3.0 are some of the worst 
that I have seen. It may work fine, but if the manual is any 
indication, I have my doubts (write and let us know if I am 
wrong). CP/M 3.0 is a good program if already implemented, 
and a real bear if not. I like 2.2 and have been able to master 
all of its strange relationships. 3.0 is new and undocumented 
other than by DRI. I hope this will change in time, but with 
all the pressure on CP/M86 and MSDOS, it looks to me like 
3.0 will die a slow death. Those who now use 2.2 will 
probably not change for many reasons. Like myself, most 
users have developed a large library of utilities. Many of 
these utUities use the disk parameter data to display 
information -these programs will need changing for the new 
data tables. Disk usage is usually low with 2.2 but becomes 
higher in 3.0, although you do gain the ability to make 
changes and additions to the system more quickly and 
easily. 

To conclude this discussion I would like to remind users 
that it is necessary to define your needs and desires before 
buying anything. As one can tell by the previous paragraph, 
I am not overly enthusiastic about 3.0. The enhancements 
and structure have become that of a programmer's 
operating system. Unix, although being touted as the 
operating system of the future, is now getting a lot of flack 
because of its complex nature. One must remember that 
these systems are written by programmers, for 
programmers, and not for the general public. An operating 
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system should allow you to use other programs freely and 
not require a lifetime of study to run. CP/M 3.0. 86. and 
MSDOS are being influenced by Unix's structure, so many of 
the newer versions may not be that desirable. One thing 
that I have tried to do in this article is "tell it like I see it.** I 
too often see articles that gloss over the bad points only to 
get inexperienced users into trouble. To those readers who 
have found many of the industry's hidden and sometimes 
dark secrets, please write articles and send them in. I have 
dealt with BIOSs for some time now. and am still amazed at 
how many secrets they contain that I have yet to find... 
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XChC 






OCFF 


FDbO 




Db 


0FPti,OB0h 


rldir 


OiCl 


Eb 




XCMC 






oic; 


C9 




SIT 






0103 


C3ACC1 


DFVTb^-. 


JMP 


motyft 




Clot 


C3AC0: 


DEv:n1 : 


JHP 


mottft 




0106 


C3ACC.i, 


FL'-'SH ; 


JMP 


MOTYFT 




OlOC 


3 210 01 


SFLorn; 


tt* 


fdbnk 




OiOF 


C9 




ret 






Olio 


00 


fdbnk; 


db 


01- 




Olil 


DJFF 


StLmmmi 


O'-T 


OFFM 




0113 


321701 




STA 


•CiKk 




Ollf 


C? 




RFT 






oil? 


oc 


•CBNK: 


OB 


OH 




one 


C3AC0i 


IMOVF ; 


JHP 


HOTYtT 




Ollb 


C3AC01 


TIME: 


JHP 


HOTYFT 




OllE 


JlFFFb 


BOOT; 


LXI SP.BTSTK 


SET STACK KJIHTFR. 






Mh 


• r. uBtr. 


tf-e bios 


for cpmldr replace 






Above line tritri cr. 


•RET- 


0121 


AF 




XRA A 






0122 


320400 




■ ta 4 






012«- 


3203OC 




STA 3 




-lOBYTE 


D12S 


324irc 




STA u 


nit 




012B 


CDSroi 


StTCPH! 


CALL SET'JP 


SfT -JP J'.'MPS. 


01 2F 


;k2oi 




LXI 


H,SHSC 




Dill 


C DA t C i 




CALL 


PHSG 




0134 


CDD7Ci 




CALL 


7Ih:t 




0137 


cDr'rc2 




CALL 


;lpccf 




Ci3A 


DbJF 




IH conpt;. 


CLEA^ CONSOLE STAT'-'S 


013C 


C300C1 




JMP 


lOOx 


JVMF TO CCP. 



for b*r. 



OlSF jfC) 

0141 32COCC 

0144 320* CC 

01«7 213300 



■-'P JVHP£ TC CP/M 



HV I A , 1 

CALL selDr.k 
MVl A,0C3W .-P'-'T JMP TC WBOOT 
ETA :A:iV AT IFRO. 

STA OiH 



LXI 



, 7WBD0T 



continued 
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Ol«* 


33010D 




»HLD 1 


014O 


2AOO0O 




LHLD 9«ixtps 


01^0 


23DtOC 




SHLD « 


01S3 


C? 




HET 






; t»»pO 


• ry Aiw. avlcci 






T&tLDSIk 




Ol** 


31OD0O 




LXI M,0 


01».7 


7» 




MOV A , C 


eisi 


rC02 




CPl 3 


01^* 


DC 




RNC 


01^8 


r*rr 




AMI OrDD 


Oi^D 


33*2rc 




ST* umT 


OltO 


314000 




LXl M.DPti 


Sl»3 


rroi 




CH 1 


0145 


CB 




m 


01«« 


Jl'.OOO 




LXl H.DPFO 


•14< 


C9 


BOMtl! 


«rT 


eiik 


010000 




LXl >.0 


«i*r 


C31F30 




}mp ««ttrk 



cifK' C3*r:. 



o:af : 

OXKT 1 

OIBC ' 

Olkl ! 

OIBI I 
OIB* 

OlBf' 1 

OiB'' ( 
OIB^ 
OlBt 

CISC < 

OIBF I 
OICO 

OlCl I 



; fvr JUMP TO •POS 
; AT. ADR 5,«,7. 
;»rT'JHN FAOM SfTVP. 



WAHH-BOCT: UFAD ALL OF CPU »ACIL IN 
IXCtPT »10S, TttEH J'JHP TO CC P . 



0170 


iirrFK 


WBOOT: 


LXl «P,bt«tk :SrT STACK FOlNTrS. 


0173 


3A*2rc 




LCA 


UWIT 


017* 


331A0: 




ST* 


TtMP 


017» 


Af 




XHA 


A 


017A 


3342rc 




■ t« 


unit 


017D 


CDFti 




CALL 


SFTVP 


01*0 


CDDEO; 




CALL 


7<LCCP 


OltJ 


JA1A03 




Ida 


tamp 


01«* 


3243FC 




■ ta 


unit 


oil* 


C300C1 




JNP 


0100m ;CC BACK TO CC P 






; CHFCH 


CDfTSOLF 1/C STAT'.'S. 


ciar 


Cr>06FO 


CONS-^-. 


CALL 


SDP^OM'O^B :HFAD COKSOLF STATVS 


our 


c» 




BFT 


:RfT'JRN FROM CONST. 






; RFAD 


A CHAB* 


ctTr f^z/K cokIclf . 






COMK: 






Ol'O 


coo9ro 




CALL SDPROW'O't'. 


01«3 


o 




RFT 








! WBITF 


» CMARACTFh T& TnF COKSC-F rFVlCT. 


01»< 


CDCcro 


COWCT ; 


CALL 


SOPROM-OCh 


Qi<f> 


c- 




RFT 




01*e 


DB^F 


COKCST ■. 


IK 


COnCTL :r,ot ir, pigir.al pre." 


01»» 


r*oi 




*hl 


Olti 


oi«: 


cs 




«: 




Ol^P 


CiFF 




API 


OFFf 


Ci»F 


C" 




RFT 




OiAC 


C3*CC, 


A'JXC'.-T: 


JWP 


NOTYFT 


ci'.s 


C jCCC* 


»,'.'X IN: 


J>1f 


SCTVFT 


01*,* 


C.'ACi, 


K.-X-.Z: 


JMP 


t.C-YFT 



A , f. 



iL "NTI. ^ If hi. 



;GFT A CHAt-kCTfii 
;lr IT'S lEIC, 



: 01 hF •!•>■:& F , 
.PRINT n. 



Old 
Olf 

oir: 
oir* 



0DCA43 
0DOA3* 
000^3*1 
4B20*.* 



Sm»y : P=F C 

po^ d 
r*t 

CBIO£ MFSSACtS 

-.5G; Dt ODh.OAH, 'CP/M 3.0 PL'.'S 

Db ODW,OAh, '8*Sr Att ' 

Dt onH,O^n,«SII'/iC-'0',MSIZF 

DB 'H V3. o f 3/ei/ 84 ' , 

WRI7F A CHARACTFii OK LIST prvlrt. 

LlSTi CALL 6DPROn-0Fh 



sn SYS^ris- 



020r 49 
0310 60 
6!U 7A 
0313 B3 

0313 C8 

0314 Cb 
021"' 09 
C316 (F 
0217 3»'0& 
0319 C« 

031A 



021B 
03«i9 



.■KET'JRN ALWAYS NOT RCAPY 



TRANSLATION ROVTINF FOLLOWS 
MOV L,C 
NOV H, B 
MOV A,D 



OOA 



TtHP; 


DS 1 








: DISA 


B'jrrrRS 


doubl* 


nor«»l 


v.lo« 


ALVOi 


OS 


43 






CSVOi 


DS 


32 






ALVl : 


DS 


42 






CSVl ; 


D£ 


33 







tit 1* 'Soot lo»d*r nodt;l« fat CP/ 
froi' DRI't (li« C\jt do*n to nmcmmaary 



VERSATILE DATA REDUCTION, 

DISPLAY AND PLOTTING SOFTWARE 

FOR YOUR APPLE* 11 






STRIPCH ARTER — Turns your APPLE and Epson MX 
series printer into an economical 4-pen chart rtcorder. 
Prints and displays continuous 1 to 4<h8nnel strip- 
charts of any length. Ideal for large data sets. Numefous 
user-selectable graphics options enhance output qual- 
ity. Includes 5 demos on disk «nth 37-page manual tlOO 

VIDICHART — Proven tool lor lab data management 
f asr plots of 4 data sets with scrolling in 4 directions. 
20om scaling on X and Y axes. 2 types of graphc 
cursors and on-screen STATUS REPORT, even plots 
AD input while sampling. ADD. SUBTRACT. MULTI- 
PLY, DIVIDE. IKiTEGRATE. DIFFERENTIATE, AVER- 
AGE or NORMALIZE data sets with SIMPLE COM- 
MANDS. Ideal for spectra, chromatograms. rate curves. 
etc Includes SAMPLE DATA on disk with 2B-page 
manual -S'S 

SCIENTIFIC PLOTTER — Draws professional-looking 
graphs of your data. You choose data tormat. length and 
position of axes. 20 symbols, error bars, labete any- 
where in 4 orientations Includes 5 demos on disk plus 
30-page manual S25 

(For DIF file and Houston Instrument or H-P 7470A 
plotter adaptations, add $25 for each option selected ) 

CURVE FITTER — Select the best cun/e to fit your data 
Scale transform, average, smooth, interpolate (3 
types) LEAST SQUARES fit (3 types). Evaluate un- 
knowns from fitted curve. Includes 5 demos on disk with 
33-page manual S35 

SPECIAL: VIDICHART. SCIENTIFIC PLOTTER. 

CURVE FITTER on 1 disk $120 

Aao S1 ,50 shipping on all U S orders VISA or MASTERCARD orders accepted 

•Trademark o1 Apple Compuier Inc 

■IT1" INTERACTIVE MICROW ARE, INC. 

1 1 i 1 1 ^-O- Box 139, Dept. 226, State College. PA 16804 
■ Um " CALL (81 4) 238-8294 for IMMEDIATE ACTION 




. -^' I 



; Inlt: don* from b»nk»d < 



02D7 312*>C3 
Cjn* CPAEOl 
03DD C9 



1x1 h .lignonSmig 
call ?p««9 
r«t 



This version of t>>* boot loader loada 

th* CCP fro<n a flla 

called CCP.COM on th« •¥■!•■« drive (M). 

?ldccp-. 

7HLCCP-. ; riitX. ll»e, load the AtCCP.COM file Into TPA 

03nF Ar336C0j Mia a I ita ecpSfCB'lS : «ero e«t*nt 

0313 J1000C337C lai h#0 I ehld fcbSnt : etart at »e9annin9 

03t» il^DOSCriil 1x1 d.ecpSfcb ! call open ; open ecp fli* 

02tE SCCAOSO) tor a I ji no$CCP : error if no file... 

02ri iloooiCDl* iKl d.oioob i call eetdMav ; etart of tfa 

02Fe llBOOOCDlB 1x1 d.l2l 1 cell eet-ialtl : allow up to l<k bytei 

03FI 115D03CD30 1x1 d.ccpSfcb ! cell reedx : Joed the thing 



0304 C9 



ret 



noSCCPt ; h«r« *' "• couldn't find t m- file 

030^ 313COJCDAr Ixi h,ccp»«Bq I Call ?P«"«y : report tMa... 

0308 CDC»00 call ?coriin : 9«t a reeponie 

030F C3Dt03 jwp Tldccp 



and try a^air. 



0311 OtOFCSOSOO 



0314 OCIACIOSOC- 



; CF/M BDOS Function Interfaces 

Mvi c.l^ 1 3»P todoe ; oper. file control block 

«vi C.34 ! 3«p Mea : eet transfer adarees 



•etnultit 
0)1B OE3CCJO?00 eivi C,*4 I ]«p bdos ; set record count 



0330 aE14C30SO0 

3 3*' 0D0A0D0A4Csignonl*isq 
033C OD0A434»4Fcep»«S9 



03%D 01l343S030ccpSf cb 

03«D 

037D 000000 feb»nr 



c,30 ! J-«P bdos 



rssd records 



1 3,10,13. 10, 'loedins 3*0 BIOS'. 1 3,10,0 
13,10, '»1CS Frr or. A: No CCP.COm ril*',C 



1, 'CCP 

1* 

0,0.0 



' , 'com' ,0,0.0,0 
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THE MCPU-30D 




FULL- ci.cii^n 

BLONA/N C9 ^31 I 

Microcomputer system on STD card 



(V2 actual size) 



Completely STD BUS 

compatible. 

4 MHz Z-80A 

64K RAM 

2K/4K/8K/16K/R0M or 

EPROM. 

Memory map under 

software control. 

24 bit parallel I/O- can also 

serve as SASl Interface for 

hard disk control. 

Serial I/O with 8 bits of 

1/0 for terminal or modem 

control. 

Three 10MHz counter/ 

timer channels. 

Completely programmable 

serial UART 

1797 Floppy diskcontroller 

handles four 5" or 8" disk 

drives. Standard drive 

connectors for both sizes 

on board. Single or double 

sided. Single or double 

density supported. All 

digital data separator. 



Parallel printer interface - 
Centronics type. 
On board interrupt 
handling logic. 
RAM is DMA controllable. 
MEMEX and lOEXP lines 
are fully implemented. 
Power-on and pushbutton 
reset circuitry. 
100 hour burn-in. 
Excellent software support 



$795 Single Quantity 



MILLER 



' 'echnoloqy Inc. 



647 N Santa Cruz Ave 
Los Gatos, CA 95030 

(408) 395-2032 



Industry hews 



Computer Pioneer Days Conference 

SYBEX Computer Pioneer Days, a new two-day 
conference to be held in San Francisco, June 15-16, 1984, 
will, for the first time, honor the "living legends" of the 
microcomputer industry, on the 10th anniversary of the 
microcomputer. (The Altair computer was introduced in 
1974.) 

The pioneer speakers represent most areas of the 
personal computer industry, from hardware, software, and 
venture capital to microchip design and development. They 
will discuss the growth of the microcomputer industry from 
their own experiences -how they started their companies or 
developed their products; who, if anyone, was with them 
from the beginning; how their first projects were financed; 
what their early successes, failures, and motivations were. 
They will offer their own perspective on the melding of 
entrepreneurship and "high technology," for themselves and 
for other people who may have wondered "what it takes" to 
strike out on an independent path. Awards for outstanding 
microcomputer industry achievements will be presented at a 



special reception on Friday, June 15, 1984, at the Hyatt 
Regency, from 7:00 to 9:00 p.m. For more information write: 
SYBEX Computer Pioneer Days, 2344 Sixth Street, 
Berkeley, CA 94710; or call (415) 848-8233. ■ 

aVi' Microfloppy New Standard? 
A paper from Hewlett-Packard entitled "Why the SVi' 
Microfloppy Will Be the Next Industry Standard" is 
available to those interested. The document outlines the 
need for standardization in the sub-5'/i ' disk drive market, 
and explains why the 3'/:' is ideally positioned to be the 
industry standard. Currently, Hewlett-packard leads the 
trend and has incorporated the 3Vi' in its entire line of 
personal computers. The paper presents a comparison of 
Hewlett-Packard's 3Vj" disk drives with the current SV*' 
products, and provides technical specifications at the end of 
the document. It can be obtained be writing: Kathy KimbaU, 
Hewlett-Packard, Greely Division, 700 71st Ave, Greely, CO 
80634. " 
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LINEAR OPTIMIZATION WITH MICROS 

A Product Review 

by The Computer Journal Staff 



The Computer Journal has been reviewing a very 
interesting software package called LO, which is short for 
Linear Optimization. The statistical technique on which this 
program is based has traditionally been done by hand; it 
.involves the simultaneous solution of a group of linear 
equations, hence the name. It was called linear programming 
before the term "programming" became associated with 
computers. 

Although the methods have been adapted to computers 
before, this is the first version your editors have seen that is 
specifically designed to run on a modest size computer. The 
version we reviewed runs under CP/M and will work fine in 
as little as 48K of memory. Considering the memory 
requirements of much current software, this is indeed a 
"plus" factor for the package. It is also avaUable for MS- 
DOS, IBM-DOS, and possibly for other formats. 

The purpose of LO, briefly expressed, is to optimize the 
use of scarce resources. It can be used either to maximize 
some desirable quality (such as profit) or minimize some 
other factor (such as cost). It is a decision-making tool which 
allows the user to weigh several variables against one 
another for optimum results. 

In business and industry we often find that several 
variables work against one another. The amount of labor 
available to produce a product, and its cost, are important 
factors. Another might be the shortage of some necessary 
material, or the amount of some product which can be 
successfully marketed. To illustrate this principle, we made 
up an example of a small computer company which builds 
CPU boards, memory boards, and video boards. The number 
of chips each requires differs, as does the number of hours 
labor to produce each, and the wage that has to be paid the 
technicians for doing the different kinds of work. Finally, we 
decided that our imaginary company has only 500 chips on 
hand (which, for our example, are all alike and will work in 
any position on any board). Our manufacturer has only $1000 
in the bank to meet the payroll, and wants the three 
available technicians to finish the job this week. 

LO problems are described in terms of "bounds" which 
are the desired product, "goals" which are the optimization 
of the bounds, and "constraints", or limits, which determine 
the final outcome. In this example we need to produce some 
number of each of the possible products; we have a limited 
number of chips with which to do so, a limited number of 
working hours, and a limit on the money we can spend for 
labor. 

The "goal" is to produce the "mix" of boards that wiU 
most effectively use our resources and yield the maximum 
profit. 

This problem is simple enough to follow but too 
complicated to be worked by hand in any reasonable length 



TIP11ZATI0N 



Hacker Products Unllaitad, prod, tlon schodula 

Llnaar Opttolxation 1.0 (c> 19ei The Acoa Co«put»r Coapany 

1 option tltla^'Hackar Pro., .eta Unllaltad, production achadula", 1 lat t 

2 boundad acpu,taaaory,avlo..oi 

3 Halt chlpB by 20lbcpu * ^S H aaaory «'12t*vld«o <-500| 

4 Halt houra by 8t*cpu ♦ S S«baa«ory *3.8«»vidao <*120| 

9 Halt coat by (SBB)B«cpu ■ <atS.S) taaaa n ry * <7«3.8) t«vidao <-10OOt 
a aaM VOItcpu * 123taaaaory * 73tavldaot 

NuMiar of itaratlonai 2 

Boal function vaiuai 2440. 



OPTIMAL 
VALUE 



EltROR 

esTinoiE 



0.000 o.oox 

4.381 o.oox 

29.24 O.oox 

aURPLUS ERPOP 

ESTIMATE 



MARGINAL 
RETURN 

-44.76 
129.0 
79.00 

MARGINAL 

VALUE 



-II»IN1TV 
108.6 

47.80 



194.8 
281.2 
86.36 



LIMIT 
REBIOM 



chips 
hours 
• cost 



O.OOO 
O.OOO 



0.001 
O.OOX 
O.OOX 



378.9 

61. 11 
819.9 



144. 1 

♦IJFINITV 



Figure 1 



of time. Figure 1 is the solution that LO produced in less 
than 60 seconds. Lines numbered 1 through 6 are the source 
file. We'll explain it line by line. 

Line 1 allows us to specify the title and instruct the 
program to list the source along with the results; this line is 
optional. Line 2 sets as bounds the number (#) of CPU 
boards, memory boards, and video boards. The solution of 
the problem will be expressed in terms of the number of 
each board we should build. 

Line 3 says that we need 20 chips for each CPU (20«#CPU) 
45 for a memory and 12 for a video board, and that the total 
cannot exceed 500 (< - 500). 

Line 4 similarly limits the hours that can be used— so 
many for each kind of board, for a total of, or less than, 120. 

Line 6 is the tricky one. It expresses the labor cost for 
each kind of board in terms of hours times pay rate (i.e.; $5 
per hour times 8 hours) and sets $1000 as the maximum that 
we can spend. 

Line 6 states our goal, which is to make the maximum 
number of CPU boards at $90 each, and/or memories at 
$125, and /or video boards at $75, and to produce these in a 
proportion that will yield the maximum sales volume. 

As the printout shows, it would be uneconomical to 
produce any CPU boards under the given conditions, but we 
can produce 4.381 memories and 25.24 video boards for a 
total of $2440 (goal function). 

The other columns have various interpretations. For 
example, they show that this solution would use all of our 
chips and all of the work hours but leave a small balance of 
our money ($184.10). Other columns give us clues as to the 
value of increasing the labor, or number of chips, or 
whatever we have to work with. After gaining experience 
with the program, these columns might enable us to modify 
our inputs and find alternate solutions. 

For example, it might seem strange that although 
memory boards are the most profitable item, we are told to 
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make fewer of them. Why? The marginal value of chips is a 
clue. Let's run the problem again pretending that we found 
250 more chips down in the basement. The result is Figure 
2. Notice that we were able to produce more memory boards 
with no increase (actually a decrease) in our labor costs! 
Evidently the number of chips we started with had a severe 
effect on our production. 





- -- - 


—~- - 


LlNEAfi OPTIMIZATION 






M«ck»r 
Linm»r 


•»roduct» linU«lt»d, produ 
Optimiation 1.0 (c» 1TO2 


-tion »ch»dul> 
Th« fiicmm Co*^>Lit»r Company 






optlCK^ titl»»"H«ck»r Products Unli«it»d, production sc 

boundsd •cpu,^MH»or y,^vld*o| 

llmt Chip* by 20l»cpu ♦ 45l««»»orv ♦I2l»vid»0 <-7SO| 

llMlt CO«t by t3t8H»cpu ♦(6iS.3H^«>»ory ♦ (7t3.B)»«^ 
mm» »Ot«cpu ♦ 123I*— »ory ♦ 75t^vi0«O| 


hvdulB-.Ustl 

id*o <-ioooi 


8oal function vftluai 


2 








VrtWIABLE 

tMne 


OPTlHAt ERWOR 
VALUE ESTinATE 


MARBIMAL 
RETURN 


COST 
REGION 




•CPU 
••vidwo 


O.OOO 
13.43 
12. 14 


O.OOX 

o.oox 
o.oox 


-64 . 76 

123.0 
73.00 


-INFINITY 
lOe.fc 

47. BO .. 


154.6 
261.2 
66.36 


LIMIT 
MATC 




SURPLUS 


ERROR 
ESTIMATE 


MARGINAL 
VALUE 


LIMIT 
REGION 




CMpV 

hour« 

• cost 




0.000 
O.OOO 
233.9 


o.oox 

0.007. 

o.oox 


0.3952 
17.86 
O.OOO 


376,'? .. 961. B 
91 .67 . . 130.7 
766.1 .. *INFINITY 










Figure 2 




1 



Getting greedy, we now raise the price of video boards by 
$10 and reduce the price of CPU boards to make up for it. 
The result is Figure 3; LO tells us to make the same mix of 
boards as in Figure 2, but at the new price we will make a 
little more profit. 

The documentation that comes with LO explains the 
formulation of problems quite well, and provides example 
problems and solutions from several kinds of activity — from 
farming (livestock feeding) to finance (stock market 
investment). 

Our impressions of the program follow; first of all, it 
works as advertised, is modestly priced, and the 
documentation is very good. It is fast and runs in a small 
memory. It can be very useful to anyone who has to make 
the kind of decisions it is designed for. It permits the use of 
sophisticated mathematical techniques by persons who 
would not otherwise be able to solve them. 

On the negative side, LO requires you to be familiar with 
your CP.^M utilities. Computer users who do not work 



LINEW OPTIMIZATION 



HACkvr ProouctB ur,li»it*d, 
Lln»«r Opti«ii«tion 1.0 <c 



production schsoul* 
) 1982 Thv Ac»« Co«put«r CoMO«n 



option tl t l»-"H«cke^ Product* L^liatitvd, 
bounded acpu, *m m mary ,»vi d>o| 



production kChddul*" I 1 1 «t 



3 1 

4 1 
3 1 


IMl t 

i»it 
i*it 


Cfiip* by 
hour« b> 
CO«t by 


20l»cpu * 
8l»cpo ♦ 9 
tSie)»»Cpu 


4S>*<M«Ory 4.l2>«vid»0 <-730| 
.9t**»«K>ry '»3.6**vid»o 0120) 

♦ <6«5.3) •••••■►ory * (7l3.e»l»> 


ld»0 <-10O0l 


6 • 


»« BOt^cpu ♦ 


12S«^— ory 


* S5t*^id»oi 




Humbmr o* 


lt»r«tlon»t 


2 








do«l function 


v«lu*i 


2711. 








VARIABLE 
NAME 




OPTIMAL 
VAI.UE 


ERROS 
ESTIMATE 


MARGINAL 
RETURN 


COST 
REGION 




•CPU 

fmmmory 
••vid*o 




O.OOC 
13.43 

12. 14 


O.OOX 
O.OOX 
O.OOX 


-98.57 

125.0 
B5.O0 


-INPINlTY .. 
123.0 
43.60 .. 


176.6 
316. 7 
86.36 


LIMIT 

NAME 




SURPLUS 


ERROR 
ESTIMATE 


MARGINAL 
VALUE 


LIMI' 
REGION 




cnip« 
hour* 
•cost 




O.OOO 
O.OOC 
233.9 


O.OOX 
O.OOX 
O.OOX 


0.07143 
22.14 
O.OOO 


37B.9 .. 981. B 

91.67 .. 130.7 

766.1 -.-INFINITY 
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RDRLnB^Rutomates lab Instruments 




• Interactive Microware's general-purpose ADALAB" data ac- 
quisition and control system interfaces with virtually any lab in- 
strument using a recorder or meter, including GC and HPLC sys- 
tems, spectrophotometers, pH meters, process control apparatus, 
thermocouples, etc. 

• Lab Data Manager'^" softwfare facilitates single or multi- 
channel acquisition, storage, display and chart recorder style out- 
put of lab instrument data. IMl QUICKI/0 softvifare operates within 
easy-to-use BASIC! 

• Thousands of scientists currently use IMl software and or 
ADALAB products worldwide' 

*Price includes 48KAPPLE^ 11+ CPU, diskdrive with controller. 
12' monitor, dot matrix printer with interface. IMl ADALAB "" inter- 
face card TTfaaen-.arr c' ADt-ie C-nru'e' i^' 

IMI'S ADALAB INTERFACE 
CARD IS AVAILABLE 
SEPARATELY FOR ONLY $495 

(lnc!udesi2-bitAD 12-biDA Sdtgila'sense inputs 8 
digiia" ccni'-o! ouiputs 32-bit rea>-time ciock, two 1 6-bi', 
timers pijs QUiCKl O data acquisition software ] 

INTERACTIVE MICROWARE, INC. 

P.O. Box 771, Dept. 226 

State College, PA 16801 (814) 238-8294 




directly with their operating system might not be ready for 
this. You write the source input with ED (or any similar 
editor) and the solution goes back onto the disk in a new file 
with an LIS extension. The only way to view the output is 
by way of the TYPE or PIP features of CP/M. 

We feel that a more "automatic" printout would be useful. 
A real bonus would be the ability to enter the variables 
interactively rather than having to compose the formulae by 
hand and write the source with the editor. Another nice 
feature (not necessary, but perhaps helpful) would be some 
"action" on the screen while the program runs. These are 
cosmetic suggestions — we are otherwise very enthusiastic 
about this software product. It is available from Acme 
Computer Co., Box 51193. Seattle, WA. for about $150. 

The level of manufacturer support is a very important 
consideration when selecting software, and we are favorably 
impressed with Acme's support of their products. One 
month after we received the program, they sent a 
questionaire with a stamped addressed envelope to obtain 
information for future revisions. Later, we received an 
announcement of a revision which can be obtained by either 
returning the original disk or sending $5 to cover the cost of 
material and handling. 

We sent Acme our comments on the program, and they 
responded by return mail to advise that most of these 
improvements are already in progress for the next revision. 
It is very unusual to find this level of support in the 
microcomputer industry, and we do not hesitate to 
recommend Acme as a supplier. ■ 
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Boohs of interest 



STD Bus Interfacing 

by Chriatopher A. Titus, Jonathan A. Titus, & David G. 

Larson. 

Another book in the BLACKSBURG Continuing Education 

Series* 

Published by Howard W. Sams, Inc. 

286 pages, 5Vi x 8Vi softbound, $13.95 

What do you do when you need a microcomputer for a 
specific application and the medium cost appliance 
computers do not have the features you need, the larger 
business computers are too expensive and still don't have 
the I/O features you need, and an S-100 bus system is 
overkill? A STD Bus system may be a good choice because 
there is a wide variety of cards available so that you can 
tailor a system to have the special features you need 
without paying for a lot of unnecessary frills. It is also 
relatively easy and inexpensive to modify the system by 
adding or replacing cards. 

This book explains the STD Bus, but even more 
importantly, it contains a very thorough explanation of what 
a microcomputer bus is, what signals are needed, and how 
these signals are used. 

The information on accumulator I/O versus memory- 
mapped I/O, addressing and address decoding, I/O 
interfacing, and interrupts is especially helpful. The book is 
written in an easy to follow manner. A good example of the 
care taken in the writing is the sample programs, which are 
written in assembly language for the 8085, Z-80, 6502, and 
6800 CPUs to make the book useful to people working with 
different CPUs. 
The contents are as follows: 

•Chapter 1 What Is The STD Bus?. Other 
Control Signals, Physical Standards, Why Use 
the STD Bus?. STD Bus Processors, Memory, 
Read-Only Memories, Read/Write Memory, 
Control Signal Generation, Memory Maps, I/O 
Devices, Memory-Mapped I/O, Accumulator I/O, 
CPU Compatibility, Data Transfer Timing, Chip 
Incompatibility, and Nonstandard Signals. 
•Chapter 2 I/O Device Addressing. Address 
and Control Signals, Device Addressing, Using 
Gates for Address Decoding, Using Decoders, 
Larger Decoders, Using Comparators, Memory- 
Mapped I/O, and Using PROMS. 
•Chapter 3 Output Port Interfacing. Output 
Timing, Latches in Output Ports, A Traffic Light 
Controller, LED Displays, Digital-to-Analog 
Converters, Data Displays, Other DAC 
Considerations, I/O Chips, and Memory-Mapped 
Output Ports. 



•Chapter 4 Input Ports. Designing Input Ports, 
An ASCII Keyboard Interface, Flags. Another 
Keyboard Interface. An Analog-to-Digital 
Converter Interface, A Simple Logic Tester, and 
Memory-Mapped Input Ports. 
•Chapter 5 Interrupts and Direct-Memory 
Access. Basic Interrupt Operation, STD Bus 
Interrupts. The 8085, The 8088, The Z-80 and 
NSC800. Serial Priority. The 6800. 6809, and 
6502, 6809 Improvements. An Interrupt Review. 
Interrupt Software. Interrupts and the Stack, 
Interrupt Timing, Direct-Memory Access, 
Requesting the Bus, Direct-Memory Access 
Controllers, and DMA Software. 
•Chapter 6 General-Interest Interface Cards. 
The Mostek DIOB/BIOP, The Enlode 214 
Display System, The Analog Devices RTl-1260, 
The Atec 710 Thumbwheel Switch Interface, The 
Matrix 7911 Stepper-Motor Controller, and the 
Pro-Log 7304 Dual UART Card. 
•Appendix A The STD Bus Standard. Organiza 
tional and Functional Specifications (With Pin 
Definitions), Electrical Specifications, and Mech- 
anical Specifications. 

•Appendix b Voltage input Configurations. 
Input Multiplexer Guidelines, and Analog Input 
Multiplexer. 

•Appendix C Index of STD Bus Manufacturers. 

The detailed information on how a bus is organized is 

worth the price of the book even if you never intend to use a 

STD bus, because this knowledge can be applied to other 

computer buses. ■ 

This book is available from Group Technology, Ltd., P.O. 
Box 87, Check, VA U072, for $13.95 plus $1.00 shipping. 
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CP/M Primer 

Helps microcomputer veterans and oovices alike find the answers about CP/M io a 
complete, one-stop sourcebook that's a Sams best-seUer! Gives you complete CP/M 
tarmiDotogy, hardware and software concepts, startup details, and more for this popular 
8060/S085,'Z-80 operating system. Helps you begin using and working with CP/M 
immediately, and includes a list of compatible software, too. By Stephen Murtha and 
Mitchell Waite. W pages, SVixll, comb. ©1980 $16.95 

Soul of CP/M: Using and Modifying CP/Ms Internal 
Features 

Teaches you how to modify BIOS, use CP/M system calls in your own programs, and 
morel Excellent for those who have read CP/M Primer or who otherwise understand 
CP/M'a outer-layer utilities. By Mitchell Waite. Approximately 160pages, 8x9 Vi, comb. 

©1983 $18.95 

The S-100 and Other Micro Buses (2nd Edition) 

Examines microcomputer bus syestema in general and 21 of the most popular systems 
in particular, including the SlOO. Helps you expand your computer system through a 
better understAnding of what each bus includes and how you can interface one bus with 
another. By Elmer C. Poc and James C. Goodwin, II. 208 pages. 5Vtx8Vi. soft. ©1981$9.95 



& Scientific Data Communications 



Interfacing 
Experiments 

This book introduces you to the principles involved in transferring data using the 
asynchronous aerial data transfer technique. It focuses on using the universal 
asynchronous receivertransmitter (UARTi chip in order to help your understanding of 
communication chips. Explores operation of teletype- writer interfaces and serial 
traosmiasioo circuits. With experiments and circuit details. By Peter R. Rooy. 160 pages, 
6Vix8Vi,»oft. ©1979 $7.95 

Active-FUter Cookbook 

A practical discussion of the many active-filter types and uses, written by one of Sams' 
most popular authors. Teaches you bow to construct filters of all types, including high- 
paas, low-p&ss. and bandpass having Bessel, Cfaebyshev, or Butterworth response. Easy to 
understand — no advanced math or obscure theory. Can also be used as a reference book 
for analyaia and synthesis techniques for active-filter specialists. By Don Lancaster. 240 
pages, 6Vix8'/i, »oft. ©1975 $14.95 

Reflated Power Supplies (3rd Edition) 

Newest, most comprehensive discussion you'll find of regulated power supplies, 
iociuding their internal architecture and operation. Thoroughly explains how to use 
regulation in your designs and projects when the need arises, and discusses practical 
eireuitry and components. A valuable book for any technician or engineer involved in 
servicing or design. By Irving M Gottlieb 424 pages. 5Vtx8Vt. toft ©1981 $19.95 

TTL Cookbook 

Popular Sams author Dan Lancaster gives you a complete look at TTL logic circuits, the 
moat inexpenaive, most widely applicable form of electronic logic. In oo-nonaense 
language, he apells out just what TTL is, how it works, and how you can use it. Many 
practical TTL applications are examined, including digital counters, electronic 
■topwatches, digiul voltmeters, ud digiul Uchometers. By Don Lancaster. 336 pages. 
B»/ix8Vi. aoft. C1974 $12.95 

IC Op-Amp Cookbook 

Ad inforiDAl, emsy-to-read ^uide covering basic op-amp theory in detaii, with 200 
practical, illuatrated circuit applications to reflect the moat recent technology. JFET and 
IIOSFET UBita are shown in both single and multiple formau Includes manufacturera' 
data aheeu, and lists addresses of the companies whose producu are featured. By Walter 
G Jung. 4«0 pagea, 6V118V1 , aoft. &1980 115.96 



IC Converter Cookbook 

Discusses and explsins data conversion fundamentals, hardware, and peripherala. A 
valuable guide to help you underatand and use d/a and mid converter applications. Includes 
msnufaeturers' daU aheeU. By Walter G. Jung. 576 pages, SVixSVi, soft. ©1978 $14.95 

IC Timer Cookbook (Second Edition) 

Learn more ways to use the IC timer in this eaay to uae second edition that includes 
msny new IC devices with ready to uae applications in prsetical, working eircuita. All 
circuits and component relationahips are fully defined and discussed for clarity. By Walter 
C. Jung. 384 pages, 5'/ii8Vi, aoft. ©1983 $17.95 

The Programmer's CP/M Handbook 

An exhaustive coversge of CP/M-80* , iu internal atructure and major components is 
presented. Written for the programmer, this volume includes subroutine exsmples for 
each of the CP/M system calls and information on bow to cuatomiie CP/M — complete with 
detailed source codes for sll examples. A dozen utility programs are ahown with heavily 
annotated C-language aouree codes. An invaluable and comprehensive tool for the serious 
programmer. By Andy Johnaon Laird. 750 pages. 7Vix9'A, softbound $21.96 

Interfacing to S-100 (IEEE 696) Microcomputers 

This book is a must if you want to design ■ custom interface between an S-100 
microcomputer and almost any type of peripheral device. Mechanical and electrical design 
is covered, along with logical and electrical relationships, bus interconnections and more. 
By Sol Libes and Mark Garetz. 322 pages, 6 Vix9>A, softbound $16.95 

Microprocessors for Measurement and Control 

You'll learn to design mechanical and proceas equipment using microprocessor-baaed 
"real time" computer systems. This book presents plans for prototype systems which 
aUow even those unfamiliar with machine or assembly language to initiate projecta. By 
D.M. Auslander and P. Sagues, 310 pages. 7 3/8x9 1/4. aoftbound $15.99 

Osborne CP/M"^ User Guide (Second Edition) 

A new revised edition which includes expanded sections on CP/M* 86 and CP/M* 80. as 
well as CP/M* s relationship to assembly language programming, MP/M* and CP/NET* 
operating environments. By Thom Hogan. 292 pages, 6 Vi x9'A , sohbound $15.95. 

Discover FORTH 

Whether you arc a beginner seeking ioformation on this multi-faceted programming 
language or a aerious programmer already using FORTH, this book is a reference that 
should not be overlooked. Long considered a computer language of building blocks, 
FORTH has been optimized for speed and requires tittle computer support. By Thorn 
Hogan. 146 pages, 6>Ax9*A. softbound $16.95 

68000 Assembly Language Programming 

Each of the 68O00's instructions is individually presented and fuUy explained in this 
tasembly language tutorial. For experienced programmers, this book is also a complete 
reference to the 68000 instruction set and programming techniquea. By Lance A 
Leventhal, 614 pages, 6Vtx9>^ , aoftbound $18.95 

Z8000® Assembly Language Programming 

This book ii filled with real-world programming examples, aample problems, and 
troubleshooting hints thst will guide the reader to mastery of this powerful new 16-bit 
"auper chip". The entire ZSOOO* instruction set is described in detail. By Lance A 
Leventhal. Adam Osborne, and Chuck CoUins. 928 pages, 6>/tx9>4, softbound $19.99 

The 8086 Book 

Anyone using, designing, or simply interested in an 8086-baaed system will be delighted 
by this book's acopc and authority. As the 16-bit microprocessor gains wider inclusion in 
small computers, this book becomes invaluable as a reference tool which covers the 
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timinf. »rchit«tiir« ud deiipi of tb« 8086. u well u optini»l programminf Uchniquei, 
iaUri*eiii(. apceul futuni. ud more. Bj Ruuell Rector ud G»org« Ainj, 624 p>(ea. 
6'Art'A, aoftbound $1*.»». 

Z80* AsMDnbly LauKiuge Programminc 

ProgTtmminf namplea iUuatrate aoftware development ooncepta ud actual aaacmbi; 
l&afuafe uaafe. More than 60 aample proKramming problema with aolutiona and a 
complete Z60* isatructioo aet reference Ubie. B; Lance A. Uventbal. 640 pagca. 
6'Ai«'*, aoftbound »»*»6- 

8080A/80S5 Assembly Lsnguage Progrsmming 

More qualitjr proframming examplea and inatruction aeta than can be found in an; 
other book on the aubject. Information on aaaemblera. program loopa, code converiion and 
more. A nuat for 8080A/80805 programmera. B; Luce A Leventhal, 448 pagei. t>hit'k. 
aoHbound »'*'5 

Microprocessor-Bftsed Robotics 

latroducea you to robotica-a djnamic new field of acience that uaea your computing 
and electronic talenu aa well aa your mechanical and electrical knowledge. Firat, jou'U 
learn the mechaniea of robot handi, arma. ud lege: then. Uctile aenaing, motion and 
attitude aenaing. and viaion ayauma. After that, you learn controlling with 
microproceeaora and BASIC programa. and finally, you learn to control the entire robot 
ayatem with voice commandal Faacinating ud lut machine apecific. By Mark J. Robillard, 
224 pagea. 8'/iXll. aoftbound $16.95 

TV Typewritter Cookbook 

Showa you how to quickly and eaaily project worda and picturea from a common, 
mieroproceaaorbaaed ayatem onto an ordinary TV aet. You'll be introduced to TVT 
eommunicationi by beat-aelling author Don Lancaater. who diacuaaea baaic TVT ayatem 
deaign, memory typea. interface circuitry, hard-copy output, and color graphica. By Don 
LucsaUr, 286 pagea, B'/ix8Vi. aoftbound $12.95 

Microcomputer Math 

A atep-by-atep introduction to binary, octal, and hexidecimal numbera, and arithmetic 
oparationa on all typea of microcompulera Excellent tor aerioua BASIC beginnera as well 
aa aaaemblyluguage programmera. Treata addition and aubtraction of binary, multiple^ 
predaion and floatingpoint operations, tractiona and acaling. Dag bits, and more. Many 
practical examples and aelf-Usts By William Barden, 160 pages. 5Vix8Vi. Boftbaund$11.95 

Understanding Digital Logic CircuJis 

A working handbook for aervice technicians and others who need to know more about 
digital eleetronica in radio, television, audio, or related areas of electronic troubleshooting 
and repair. You're given an overview of the anatomy of digiul logic diagrams and 
introduced to the many commercial IC packages on the market. By Robert G. Middleton. 
W2 pagea. B'/ix8Vi. aoftbound $18.95. 

CMOS Cookbook 

One of the beat-aelling technical books on the market, this cookbook gives you a aolid 
underaUnding of CMOS technology and iu appbcation to real world circuitry. Explains 
bow CMOS differs from other MOS designs, how it's powered, and what its advanUges 
are over other eonatructiona. The final chapter ahows you how to put all preceding 
information to work constructing aeveral large-acale, working inatrumenta Includes a 
mini-catalog of more thu 100 devices, with pinouU ud application notes. By Don 
Lucaaur, 416 pagea, 6'/ix8Vi, aoftbound $13.95 



Real Time Programming: Neglected Topics 

Thia book preaenta an OTiginal approach to the terma, akilla. and atandard hardware 
devicea needed to connect a computer to numerous peripheral devicea. It diatiUa technical 
knowledge uaed by hobbyiaU and computer aeientiaU alike to uaeable, eomprehenaible 
methoda. It explaina auch computer and eleetronica concepta aa aimple and hierarchical 
intemipU. porta. PIAa, timera, eonvertera. the aampling theorem, digital filura, ckwed 
loop control ayatcma, multiplexing, buaea, communication, and diatributed computer 
ayatema. By Caxton C, Foater. 190 pagea, 6>Ax9>A , aoftbound $9.95 

Interfacing Microcomputers to the Real World 

Here ia a complete guide for using a microcomputer to computerixc the home, office, or 
laboratory. It ahowa how to deaign ud build the interfaces neceaaary to connect a 
mieroeompuUr to real-world devicea. With thia book, microeomputera can be programmed 
to provide faat, accurate monitoring and control of virtually all electronic functions — from 
controlling kouaelighu, thermoaUU, aenaora. ud awitchea, to operating motors, 
keyboarda, ud diaplays. This book is baaed on both the hardware and software principles 
of the Z80 microproceaaor (found in aeveral minicompuUra, Tudy Corporation'a famous 
TRS-80, and otheral. By Murray Sargent ni ud Richard Shoemaker, 288 pagea. t'kt»'k, 
aoftbound »16.66 

Mastering CP/M 

Now you cu uae CP/M to do more thu juat copy filea. For CP/M uaera or ayatema 
programmera -thia book takea up where our CP/M handbook leavea off. It will give you 
an in-depth underaUnding of the CP/M modulea auch aa, CCP (Conaole Command 
Proceaaor). BIOS (Baaic Input/Output Syateml. and BDOS (Baaic Duk Operating SyatemI 
Find out how to: incorporate additional peripherala with your ayatem, uae conaole 110, uae 
the file control block ud much more. Thia book includes a apecal feature -a library of 
uaeful macros. A comprehenaive aet of appendicea ia included aa a practical reference tool. 
Take advantage of the veraatility of your operating ayaumi By Alan R. Miller. 898 pagea. 
e"x9-, aoftbound «1«»6 

Designing With the 8088 Microprocessor 

If you're aearching for an introduction to aoftware and hardware deaign using the 8088, 
you will find this book to be indispensable. After deacribing the 8088. the author leada you 
aUp-by-atep through the complete sysum design of a powerful, yet inexpenaive, aingle^ 
board controller. This single-board controller design Ulustraua a typical application of the 
8088, uaing 64K-bit dynamic RAMs. the 8203 VLSI dyncamic RAM controller, and auteof- 
the-art peripherals such aa the 8254 programmable interval timer and the 8274 multi 
protocol aerial controller. Controller aoftware deaign ia alao deaeribed in deuil-from the 
basic aaaembly language teat programs to high-level language inUrrupt control 
procedures. In addition, the 80188 aoftware and hardware enhancements are briefly 
described. By John Zarrella, 304 pagea, 6'x9', aoftbound $19.96 

FORTH Tools, Volume One 

FORTH Tools is a comprehenaive introduction to the new international FORTH-83 
Sundard and all ita extenaions. It gives careful treatment to the CREATEDOES 
construct, which ia uaed to extend the language through new claaaea of intelligent dau 
atnicturea. FORTH Toola givea the reader u in-depth view of input and output, from 
reading the input stream to writing a aimple mailing liat program. Each topic ia preaented 
with practical examples ud numerous Ulustrationa. Problems (ud solutions) are provided 
at the end of each chapter. FORTH TooU U the required Uxtbook for the UCLA ud IC 
Berkeley extenaion couraes on FORTH. By AniU Andereon and Martin Tracy. 218 pages. 
6'Ax8'A. aoftbound •*"•'* 
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Port Expanders from Computer Accessories 
Corporation 

Computer Accessories Corporation (San Diego) now offers 
a way to avoid the cost of added slotware when additional 
devices need to be connected to a computer I/O 
(input/output) port. The answer is a series of "port traffic 
cops" — port expanders with A/B/C switch routing— that can 
switch one port to any of three devices, or one device to any 
of three ports. Six Data Director models are available: three 
in stand-alone cabinets, available for $199 each (suggested 
US resale), and three designed to fit inside Computer 
Accessories' Model P12 Power Director* fline-conditioning 
power control accessory) cabinet, available for $189 each. 

Three models in each series each meet a specific 
connector need for a given port or system. For standard RS- 
232 serial ports. Data Director offers DB25 female (models 
Q13/Q23) or male (models Q14/Q24) connectors. For standard 
parallel (printer) ports, Data Director (models Q15/Q25 offers 
36-pin Centronics-stlye connectors. 

Data Directors boast printed curcuit board construction 
(which is more reliable than point-to-point wiring with 
individual wires) and use sealed rotary switches (to avoid 
data errors from the effects of contamination on switch 
contact integrity). Each model is fully shielded, and a full 
line of supportins cables is available from Computer 
Accessories. A P12 Power Director complete with a Data 
Director is available for $388, or alone for $199. It's designed 
to fit atop an IBM* PC system unit (or others with its 19 Vi 
by 13 Vi footprint). 




For additional information, contact Computer Accessories 
Corporation, 7696 Formula Place, San Diego, CA 92121; (619) 
695-3773. ■ 



Free Catalog From Group Technology 

The Spring 1984 catalog contains descriptions of all of the 
new and current books and products available from Group 
Technology, Ltd. It is directed particularly to those who 



wish to gain or teach hands-on experience in interfacing 
external devices to microcomputers. The experiment-based 
books that comprise the world-renowned Blacksburg Series 
provide practical g^uidance in acquiring these skills. Topics 
covered include the major 8-bit and 16-bit microprocessors, 
analog and digital electronics, electronic data processing, 
robotics, circuit design, machine design, electronic music and 
speech synthesis, fiber optics, microcomputers in astronomy, 
FORTH language, and more. Hardware described includes 
interfacing and circuit design boards for the Apple II, 
Timex/Sinclair, Commodore 64 and Vic-20. TRS-80 Models I, 
III, 4, and Color Computer. Software listed includes utility 
programs for the TRS-80; scientific software for the Apple 
II + le for a variety of curvefitting and parameter estimation 
problems; and a LISP interpreter for the IBM PC. 

Both novice and experienced microcomputer enthusiasts 
will find a treasury of practical resource material in the 
catalog. It is available without charge from Group Technology, 
Ltd., PO Box 87, Check, VA 24072, tel. 703-651-3153. ■ 



Computer nostalgia: 

how Personal Computers have Changed 

j/jf hen micros first appeared, in the middle 1970s, 
memory was precious. Microsoft made a 4K BASIC 
(that's how much memory it occupied) and there was 
even a smaller version, known as "Tiny BASIC," which 
would run successfully in computers having less than 
4K of total memory. Many now-familiar features were 
sadly missing; versions with only integer numbers and 
no arrays at all were not unusual. 

Nowadays, BASIC may occupy 16K or so of ROM, or 
be loaded from disk into 32K or more of your avaUable 
memory. It usually comes free when you buy your 
computer. 

Altair (the first mass-marketed micro) in 1975 
advertised IK memory boards for $139, 4K boards for 
$338, and a single disk drive for $1980. The 4K BASIC 
was $350, the 8K version was $500. You could buy the 
source listing of BASIC (in case you wanted to modify 
it?) for $3000. 

The Altair 8800, the original "S-100" computer, was 
sold in 1975 for $439 in kit form or $621 assembled. It 
came (in either version) with 4 slots and two boards. 
One board was the CPU; the other was a 'AK (that's 
right, one fourth of a K, or 256 bjrtes) board that could 
be expanded all the way up to a full IK by adding six 
additional memory chips! Kits were avaUable to add 
more S-100 slots; if you added enough you could cram 
in enough memory to run one of those early versions 
of BASIC. ■ 



LEARN MICROCOMPUTER INTERFACING 
VISUALIZE SCIENCE PRINCIPLES 

Using GROUP TECHNOLOGY BREADBOARDS with your 
APPLE® ...COMMODORE 64® ...TRS-80® ...TIMEX-SINCLAIR® ...VIC-20® 

Versatile breadboards and clearly written texts with detailed experiments provide basic Instruction in interfacing mi- 
crocomputers to external devices for control and information exchange. They can be used to provide vivid illustrations of 
science principles or to design interface circuits for specific applications. Fully buffered address, data, and control buses 
assure safe access to decoded addresses. Signals brought out to the breadboards let you see how microcomputer signals 
flow and how they can be used under BASIC program control to accomplish many useful tasks. 

Texts for these breadboards have been written by experienced scientists and instructors well-versed in conveying 
ideas clearly and simply. They proceed step-by-step from initial concepts to advanced constructions and are equally 
useful for classroom or individual instruction. No previous knowledge of electronics is assumed, but the ability to program 
in BASIC is important. 

The breadboards are available as kits or assembled. Experiment component packages include most of the parts 
needed to do the experiments in the books. Connecting cables and other accessory and design aids available make for 
additional convenience in applying the boards for classroom and circuit design objectives. Breadboard prices range from 
$34.95 to $350.00 



n\^ 





The FD-ZX1 I/O board provides access to the Timex- 
Sinclair microcomputer for use in automated measure- 
ment, data acquisition, and instrument control applica- 
tions. A number of science experiments have been 
developed to aid teachers in illustrating scientific 
principles. The operating manual contains instructions for 
constructing input and output ports. A complete text of the 
experiments will be available later in 1984. The FD-ZX1 can 
be used with Models 1000, 1500, 2068, ZX81, and Spectrum. 



The INNOVATOR' BG-Boards designed by the pro- 
ducers of the highly acclaimed Blacksburg Series of books 
have gained wide acceptance for teaching microcomputer 
interfacing as well as for industrial and personal applica- 
tions. Detailed, step-by-step instructions guide the user 
from the construction of device address decoders and 
input/output ports to the generation of voltage and current 
signals for controlling servo motors and driving high- 
current, high-voltage loads. BG-Boards are available for the 
Apple II, II -t- , He; Commodore 64 and VIC-20: TRS-80 Model 
1 with Level II BASIC and at least 4K read/write memory, 
Models 111 and 4. The books, Apple Interfacing (No. 21862) 
and TFIS-80 Interfacing Books 1 and 2 (21633, 21739) are 
available separately. 

The Color Computer Expansion Connector Breadboard (not shown) for the TRS-80 Color Computer makes it possible 
to connect external devices to the expansion connector signals of the computer. Combined with a solderless bread- 
board and the book TRS-80 Color Computer Interfacing. With Experiments (No. 21893), it forms our Model CoCo-100 In- 
terface Breadboard providing basic interfacing instructions for this versatile computer. Experiments in the book show 
how to construct and use a peripheral interface adapter interface, how to input and output data,-and how digital-to-analog 
and analog-to-digital conversion is performed. 

Our new Spring Catalog describes the interface breadboards, dozens of books on microcomputer Interfacing, pro- 
gramming, and related topics including the famous Blacksburg Continuing Education Series, a resource handbook for 
microcomputers in education, and a comprehensive guide to educational software; utility software for the TRS-80, 
scientific software for the Apple II, and other topics. We give special discounts to educational institutions and Instructors. 
Write for the catalog today. 



Apple II. tl + . and He are registered 
trademarks ot Apple Computer Inc : 
Commodore 64 and VIC-20 are 
registered trademarks of Commodore 
Business Machines: TRS-80 is a 
registered trademark ot Radio Sriack. 
a Tandy Corporation; Timex/Sinclair 
is a registered trademark ot Timex 
Computer Corporation 



PUTTING 
HANDS 
AND 
MINDS 
TOGETHER 




Group Technology, Ltd. 
P.O. Box 87N 
Check, VA 24072 
703-651-3153 
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